0

我正在尝试使用 Google Places API 查找最近的建筑物/地点名称,但我对为什么即使您输入了确切的坐标也没有包含在结果中的某些地点感到困惑。

例如,如果我在谷歌地图上搜索“UCLA Murphy Hall”,谷歌地图就能找到该建筑物并返回其地理编码。但是,如果您将该地理编码输入到附近搜索 API 中,则无论搜索半径如何,返回的结果都不包括建筑物。

我的问题是:

  • 为什么您可以通过谷歌地图文本搜索搜索的内容与您可以从附近的 API 获得的内容有所不同?
  • 如果我希望能够从地理编码 (34.0715597,-118.4392192) 中找到建筑物的名称,我应该使用什么?
  • 映射地理编码的最佳方法是什么->最近的完整街道地址(带有街道号码)->最近的建筑物/企业?

先谢谢了!

4

2 回答 2

0

要将地理编码转换为完整的街道地址,我建议您尝试我们的反向地理编码服务。使用上述位置坐标,反向地理编码返回“410 Charles E Young Drive, UCLA, Los Angeles, CA 90024, USA”

于 2013-08-27T01:44:52.837 回答
0

这是我的一个旧项目中的一些代码:

  • 映射地理编码的最佳方法是什么 - >最近的完整街道地址(带有街道号码)

第一个函数根据您提供的 lat & lng 获取最近的街道坐标 第二个函数获取第一个函数返回的坐标的格式化地址

    // get nearest coords based on given tracking
tb.prototype.getNearestStreetCoords = function(lat, lng, callback) {

    var parentClass = this;

    var nearestStreet = {
        latitude: lat,
        longitude: lng
    };

    if (parentClass.useNearest != true) callback(nearest); 

    var request = {
        origin: new google.maps.LatLng(lat, lng), 
        destination: new google.maps.LatLng(lat, lng),
        travelMode: google.maps.DirectionsTravelMode.DRIVING
    };

    directionsService = new google.maps.DirectionsService();

    directionsService.route(request, function(response, status) {


        if (status == google.maps.DirectionsStatus.OK) {       
            callback(response);
        } else {
            callback(false);
        }

    });     
}

    // get nearest formatted address based on lat & lng
tb.prototype.getAddress = function(lat, lng, callback) {

    geocoder = new google.maps.Geocoder(); 
    geocoder.geocode({'latLng': new google.maps.LatLng(lat, lng)}, function(results, status) {

        if (status == google.maps.GeocoderStatus.OK) {
            callback(results[0].formatted_address);
        } else {
            callback(false);
        }

    }); 
}

更新

距离计算函数,用 php 编写的 2 个 lat - lng 点之间。

function distance($lat1, $lon1, $lat2, $lon2, $unit = 'M') {

        $theta = $lon1 - $lon2;
        $dist = sin(deg2rad($lat1)) * sin(deg2rad($lat2)) +  cos(deg2rad($lat1)) * cos(deg2rad($lat2)) * cos(deg2rad($theta));
        $dist = acos($dist);
        $dist = rad2deg($dist);
        $miles = $dist * 60 * 1.1515;
        $unit = strtoupper($unit);

        if ($unit == 'K') {
            return ($miles * 1.609344);
        } else if ($unit == 'N') {
            return ($miles * 0.8684);
        } else {
            return $miles;
        }
    }
于 2013-09-05T12:16:15.793 回答