基于Google Place服务附近搜索结果的正确地图中心的位置

时间:2016-05-13 03:14:47

标签: javascript html google-maps google-maps-api-3 google-places-api

此代码成功获取从自动填充字段传递的localStorage place id变量(可以单击“Map It”并在出现的弹出窗口中输入一个位置,在roadtripsharing.com上进行测试),并创建一个标记,信息窗口和圈子。我包含了一个默认位置{lat:39,lng:-105},以防用户直接访问该页面而不使用任何localStorage。然而,即使我从主页上存储并存储在本地存储中的东西,出现的地方(在这种情况下是ATM机)都集中在美国科罗拉多斯普林斯,这是{lat:39,lng:-105 }。

我相信在宣布

var request = {
        location: mapit.getCenter(),
        radius: 5000,
        //  query: 'atm'
        types: ['atm']
      };

mapit.getCenter()应该是results [0] .geometry.location(基于从主页传递的localStorage Place ID的标记位置)。如何使附近的地方服务搜索结果使用此作为位置而不是始终{lat:39,lng:-105}?

function initMapIt() {    
  var mapit = new google.maps.Map(document.getElementById('mapitmap'), {
      center: {lat: 39, lng: -105},
      zoom: 11,
      mapTypeId: google.maps.MapTypeId.ROADMAP
    });  
  var rtscircle = new google.maps.Circle({
        radius:document.getElementById("rtsfader").value*1609.34, 
        strokeWeight: 2,
        strokeColor: "blue",
          strokeOpacity: 0.9,
        fillColor: "red",
        fillOpacity: 0.15,
          clickable: false,
        map: mapit
        });
  if (localStorage.placetopass !== null){
    var rtsgeocoder = new google.maps.Geocoder;
    var newplace = localStorage.getItem('placetopass');
    rtsgeocoder.geocode({'placeId': newplace}, function(results, status) {
    if (status === google.maps.GeocoderStatus.OK) {
      if (results[0]) {
        mapit.setZoom(11);
        mapit.setCenter(results[0].geometry.location);
        var rtsmarker = new google.maps.Marker({
          map: mapit,
          position: results[0].geometry.location
        });
        var rtsinfowindow = new google.maps.InfoWindow;
        rtsinfowindow.setContent(results[0].formatted_address+'<p><a href="http://roadtripsharing.com/rate-place">Rate this place?</a></p>');
        rtsinfowindow.open(mapit, rtsmarker);
        rtsmarker.addListener('click', function() {
          rtsinfowindow.open(mapit, rtsmarker);
        });
        rtscircle.setCenter(results[0].geometry.location);
        jQuery("#rtsfader").change(function(){
          rtscircle.setRadius(document.getElementById("rtsfader").value*1609.34);
        });
      }                           
         else {
        rtscircle.setCenter({lat: 39, lng: -105});   
      }
    } else {
      rtscircle.setCenter({lat: 39, lng: -105});
    }
  });
  document.getElementById("rts-aahs").play();
  }
  var request = {
    location: mapit.getCenter(),
    radius: 5000,
    //  query: 'atm'
    types: ['atm']
  };
  var infowindow = new google.maps.InfoWindow();
  var service = new google.maps.places.PlacesService(mapit);
  service.nearbySearch(request, callback);

function callback(results, status) {
  if (status == google.maps.places.PlacesServiceStatus.OK) {
    for (var i = 0; i < results.length; i++) {
      createMarker(results[i]);
      console.log(results[i]);
    }
  }
  else
      alert("Status not OK");
}

function createMarker(place) {
    // alert("createMarker function");
  var placeLoc = place.geometry.location;
  var marker = new google.maps.Marker({
    map: mapit,
    position:  place.geometry.location
  });
  console.log(marker);
  google.maps.event.addListener(marker, 'click', function() {
    infowindow.setContent(place.name);
    infowindow.open(mapit, this);
  });
}

}

1 个答案:

答案 0 :(得分:1)

问题是您在致电mapit.getCenter()之前致电mapit.setCenter(results[0].geometry.location) 。发生这种情况是因为您在rtsgeocoder.geocode(...)的回调中更新了地图中心,但在继续执行nearbySearch之前,您不会等待它运行。您可以在console.log / getCenter来电之前添加几个setCenter来电,并观察发生的顺序,轻松验证这一点。

要解决此问题,您可以尝试以下方法之一:

  1. 等待rtsgeocoder.geocode的某个截止日期(例如2秒)在调用getCenter之前运行其回调(以及基于它的nearbySearch)。这不是很强大,例如,慢速网络链接可能意味着它需要超过2秒,同时你没有标记来显示你的用户。
  2. 从您的nearbySearch回调中立即致电rtsgeocoder.geocode - 或者甚至每次更改地图中心时。因为向地图添加大量标记可能会消耗内存并减慢页面速度,所以当您获得新标记时,您可能希望删除旧标记。例如,通过保留createMarker函数添加的一系列标记,并在每个标记上调用marker.setMap(null)
  3. 我认为选项2通常是更好的选择。