1

我正在开发一个业务目录网站,其搜索将由谷歌地图驱动。用户将能够根据各种标准搜索他们所在地区的企业,但主要的想法是,如果您搜索“新泽西州的管道工”,您将获得新泽西州所有管道工的结果。但是,如果您搜索“泽西海岸的水管工”,您应该只找到在泽西海岸工作的水管工,在本示例中,该水管工将是大新泽西州的郊区或其他类型的分区。顺便说一句,我去掉了“管道工”,只传递了实际的地理搜索词,所以我实际的谷歌地图搜索只有“新泽西”或“泽西海岸”。所以不要专注于实际的搜索文本本身。

这是我的搜索片段:

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 英里(这些数字直接来自我的耳朵,而不是实际的地图)。

4

1 回答 1

2

地理编码器还返回结果的视口和边界。如果您需要直径,您可以将其中一个转换为距离(边界的宽度或高度将为您提供直径,如果不使用该边界来限制您的搜索。

于 2013-10-01T14:20:41.650 回答