6

我正在使用 Google Maps API v3 和 javascript 向网站添加地图。

我有一个地址列表,并已成功将它们绘制在地图上。当用户输入邮政编码时,地图会重新以他们的位置为中心,显示最接近该点的标记。现在,我需要创建一个列表视图,其中包含离他们的邮政编码最近的 3 或 5 个位置以及行车方向的链接。我被困住了......并愿意接受建议。

4

2 回答 2

13

通常的解决方案是使用google.maps.geometry.spherical 库computeDistanceBetween(from:LatLng, to:LatLng, radius?:number) 方法将数字减少到 10 左右,然后使用距离矩阵将行驶距离返回给那些位置,因此可以按行驶距离(实际行驶距离)对结果进行排序,并在请求限制内按实际行驶距离减少到最近的 3 到 5 个位置。

示例(从列表中找到 3 个最近的地方) (从 FusionTables “披萨店”示例中借用的数据)

  function codeAddress() {
    var address = document.getElementById('address').value;
    geocoder.geocode( { 'address': address}, function(results, status) {
      if (status == google.maps.GeocoderStatus.OK) {
        map.setCenter(results[0].geometry.location);
    if (customerMarker) customerMarker.setMap(null);
        customerMarker = new google.maps.Marker({
            map: map,
            position: results[0].geometry.location
        });
    closest = findClosestN(results[0].geometry.location,10);
        // get driving distance
        closest = closest.splice(0,3);
        calculateDistances(results[0].geometry.location, closest,3);
      } else {
        alert('Geocode was not successful for the following reason: ' + status);
      }
    });
  }

function findClosestN(pt,numberOfResults) {
   var closest = [];
   document.getElementById('info').innerHTML += "processing "+gmarkers.length+"<br>";
   for (var i=0; i<gmarkers.length;i++) {
     gmarkers[i].distance = google.maps.geometry.spherical.computeDistanceBetween(pt,gmarkers[i].getPosition());
     document.getElementById('info').innerHTML += "process "+i+":"+gmarkers[i].getPosition().toUrlValue(6)+":"+gmarkers[i].distance.toFixed(2)+"<br>";
     gmarkers[i].setMap(null);
     closest.push(gmarkers[i]);
   }
   closest.sort(sortByDist);
   return closest;
}

function sortByDist(a,b) {
   return (a.distance- b.distance)
}

function calculateDistances(pt,closest,numberOfResults) {
  var service = new google.maps.DistanceMatrixService();
  var request =    {
      origins: [pt],
      destinations: [],
      travelMode: google.maps.TravelMode.DRIVING,
      unitSystem: google.maps.UnitSystem.METRIC,
      avoidHighways: false,
      avoidTolls: false
    };
  for (var i=0; i<closest.length; i++) request.destinations.push(closest[i].getPosition());
  service.getDistanceMatrix(request, function (response, status) {
    if (status != google.maps.DistanceMatrixStatus.OK) {
      alert('Error was: ' + status);
    } else {
      var origins = response.originAddresses;
      var destinations = response.destinationAddresses;
      var outputDiv = document.getElementById('side_bar');
      outputDiv.innerHTML = '';

      var results = response.rows[0].elements;
      for (var i = 0; i < numberOfResults; i++) {
        closest[i].setMap(map);
        outputDiv.innerHTML += "<a href='javascript:google.maps.event.trigger(closest["+i+"],\"click\");'>"+closest[i].title + '</a><br>' + closest[i].address+"<br>"
            + results[i].distance.text + ' appoximately '
            + results[i].duration.text + '<br><hr>';
      }
    }
  });
}

上面带有 infoWindow 中“获取路线”链接的示例

于 2013-06-24T17:49:57.387 回答
0

当您拥有邮政编码的 lat lng 对时,您可以使用 harversine 公式来查找与您所在位置的距离。

于 2013-06-24T17:02:01.577 回答