1

Google マップ V3 で 5 つのマーカー間の距離をどのように計算しますか? 私が調査したHaversine式を使用する必要があることはわかっており、2つのマーカー間の距離の計算について教えている投稿をここで見つけました。5 つのマーカー間で計算したい場合はどうすればよいですか? 数時間試してみましたが、計算された km は非常に間違っています。ありがとう

次のコードは次のとおりです。

// compute distance between the two points
    var R = 6371; // KM
    var dLat = toRad(location5.lat()-location4.lat()-location3.lat()-location2.lat()-location1.lat());
    var dLon = toRad(location5.lng()-location4.lng()-location3.lng()-location2.lng()-location1.lng()); 

    var dLat1 = toRad(location1.lat());
    var dLat2 = toRad(location2.lat());
    var dLat3 = toRad(location3.lat());
    var dLat4 = toRad(location4.lat());
    var dLat5 = toRad(location5.lat());

    var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
            Math.cos(dLat1) * Math.cos(dLat1) * 
            Math.sin(dLon/2) * Math.sin(dLon/2); 
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
    var d = R * c;

    document.getElementById("distance_direct").innerHTML = "<br/><br/><br/>The distance between the five points (in a straight line) is: "+d +" Km.";
}

function toRad(deg) 
{
    return deg * Math.PI/180;
}

私の間違った部分は、var a formula で始まる行にあると思います。間違っている場合はエラーを示してください。解決策があれば教えてください。

4

2 に答える 2

2

Google Maps V3 の computeLength() 関数は、必要なものを提供するはずです。http://code.google.com/intl/el/apis/maps/documentation/javascript/geometry.html#Distance を参照してください。

于 2012-01-25T18:07:15.887 に答える
0

使用している関数は、2 つの座標間の距離用です。A->B から B->C までの距離を計算し、それらの距離を最後に加算する必要があります。

var distAB = calcDist(location1,location2);
var distBC = calcDist(location2,location3);
var distCD = calcDist(location3,location4);
var distDE = calcDist(location4,location5);

var distTotal = distAB + distBC + distCD + distDE;

function calcDist(locationA,locationB)
{
    var R = 6371; // KM
    var dLat = toRad(locationB.lat()) - toRad(locationA.lat());
    var dLng = toRad(locationB.lng()) - toRad(locationA.lng());
    var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
        Math.cos(dLat1) * Math.cos(dLat1) * 
        Math.sin(dLon/2) * Math.sin(dLon/2); 
    var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
    return R * c;
}

function toRad(deg) 
{
    return deg * Math.PI/180;
}
于 2012-01-25T18:21:48.360 に答える