0

Google Places API を使用して最も近い建物/場所の名前を見つけようとしていますが、正確な座標を入力しても一部の場所が結果に含まれない理由に混乱しています。

たとえば、Google マップで「UCLA Murphy Hall」を検索した場合、Google マップは建物を見つけてジオコードを返すことができます。ただし、そのジオコードを Nearby 検索 API に入力した場合、検索範囲に関係なく返される結果には建物が含まれません。

私の質問は次のとおりです。

  • Google マップのテキスト検索で検索できるものと近くの 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

これは、私の古いプロジェクトのコードです。

  • ジオコードをマッピングするための最良の方法は何ですか - >最も近い完全な住所(番地付き)

最初の関数は、提供された緯度と経度に基づいて最も近い通りの座標を取得します 2番目の関数は、最初の関数が返した座標のフォーマットされた住所を取得します

    // 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点間の距離計算機能。

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 に答える