Google Places API附近搜索丢失的地方

时间:2013-08-26 21:28:36

标签: google-maps google-places-api

我正在尝试使用Google Places API查找最近的建筑物/地名,但是为什么即使您输入了确切的坐标,为什么有些地方不会包含在结果中。

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

我的问题是:

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

先谢谢!

2 个答案:

答案 0 :(得分:0)

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

答案 1 :(得分:0)

以下是我的一个旧项目的一些代码:

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

第一个函数根据lat& amp;得到最近的街道坐标。你提供的 第二个函数获取第一个函数返回的坐标的格式化地址

    // 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);
        }

    }); 
}

<强>更新

距离计算功能,在2个lat-lng点之间用php编写。

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;
        }
    }