我正在开发一个业务目录网站,其搜索将由谷歌地图驱动。用户将能够根据各种标准搜索他们所在地区的企业,但主要的想法是,如果您搜索“新泽西州的管道工”,您将获得新泽西州所有管道工的结果。但是,如果您搜索“泽西海岸的水管工”,您应该只找到在泽西海岸工作的水管工,在本示例中,该水管工将是大新泽西州的郊区或其他类型的分区。顺便说一句,我去掉了“管道工”,只传递了实际的地理搜索词,所以我实际的谷歌地图搜索只有“新泽西”或“泽西海岸”。所以不要专注于实际的搜索文本本身。
这是我的搜索片段:
var latlng = results[0].geometry.location;//results is google maps search result for address
console.log(results[0]);
map.setCenter(latlng.lat(), latlng.lng());
map.addMarker({
lat: latlng.lat(),
lng: latlng.lng(),
icon: 'https://maps.google.com/mapfiles/kml/shapes/schools_maps.png'
});
var closestmarkers = [];
var MAXDISTANCE = 5;//radius of our search area in km
closestmarkers = find_n_closest_markers(latlng, n, MAXDISTANCE);//see below snippet for function definition
这是确定哪些标记最接近搜索的 javascript:
function find_n_closest_markers(latlng, n, MAXDISTANCE){
var lat = latlng.lat();
var lng = latlng.lng();
var R = 6371; // radius of earth in km
var distances = [];
var closest = -1;
for (i = 0; i < map.markers.length; i++) {
var mlat = map.markers[i].position.lat();
var mlng = map.markers[i].position.lng();
var dLat = rad(mlat - lat);
var dLong = rad(mlng - lng);
var a = Math.sin(dLat / 2)
* Math.sin(dLat / 2)
+ Math.cos(rad(lat))
* Math.cos(rad(lat))
* Math.sin(dLong / 2)
* Math.sin(dLong / 2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1 - a));
var d = R * c;
distances[i] = { distance: d, index: i };
}
distances.sort(comparedistances);
//remove all distances greater than MAXDISTANCE
toofarindex = -1;
for (j = 0; j < distances.length; j++)
{
if(distances[j].distance >= MAXDISTANCE)
{
toofarindex = j;
break;
}
}
if (toofarindex != -1)
{
distances = distances.splice(0, toofarindex - 1);
}
//return first n + 1 items(the closest marker is the one indicating the user's current/preferred location. which doesn't count)
if (distances.length > n + 1)
{
distances = distances.splice(0, n + 1);
}
return distances;
}
我不关心实际功能。这100%有效。我正在寻找的是如何根据搜索词确定 MAXDISTANCE 的值应该是多少。5 现在只是一个很好的折衷常数,但我需要知道新泽西的直径是 20 英里,而泽西海岸只有 5 英里(这些数字直接来自我的耳朵,而不是实际的地图)。