web-dev-qa-db-ja.com

リーフレットの2点間の距離を計算する

Leaflet-ionic2の2つのマーカー間の距離をどのように計算しますか?

わかりませんでした。マーカーを選択するとすぐにアルゴリズムが実行され、自分の場所とマーカーの間の距離が表示されます。

ありがとう。

13
Taieb

この関数を使用して、2つの位置間の距離を見つけることができます。

function getDistance(Origin, destination) {
    // return distance in meters
    var lon1 = toRadian(Origin[1]),
        lat1 = toRadian(Origin[0]),
        lon2 = toRadian(destination[1]),
        lat2 = toRadian(destination[0]);

    var deltaLat = lat2 - lat1;
    var deltaLon = lon2 - lon1;

    var a = Math.pow(Math.sin(deltaLat/2), 2) + Math.cos(lat1) * Math.cos(lat2) * Math.pow(Math.sin(deltaLon/2), 2);
    var c = 2 * Math.asin(Math.sqrt(a));
    var EARTH_RADIUS = 6371;
    return c * EARTH_RADIUS * 1000;
}
function toRadian(degree) {
    return degree*Math.PI/180;
}
var distance = getDistance([lat1, lng1], [lat2, lng2])

この関数をライブラリ time-aware-polyline で使用して、タイムスタンプ付きの緯度経度情報をエンコードしています。

11

リーフレットマニュアル は、距離をメートル単位で計算するdistanceTo関数について言及しています。

Google Groups から盗用された例:

function createMarker()
{
     var markerFrom = L.circleMarker([28.6100,77.2300], { color: "#F00", radius: 10 });
     var markerTo =  L.circleMarker([18.9750,72.8258], { color: "#4AFF00", radius: 10 });
     var from = markerFrom.getLatLng();
     var to = markerTo.getLatLng();
     markerFrom.bindPopup('Delhi ' + (from).toString());
     markerTo.bindPopup('Mumbai ' + (to).toString());
     map.addLayer(markerTo);
     map.addLayer(markerFrom);
     getDistance(from, to);
}

function getDistance(from, to)
{
    var container = document.getElementById('distance');
    container.innerHTML = ("New Delhi to Mumbai - " + (from.distanceTo(to)).toFixed(0)/1000) + ' km';
}
6