1. ホーム
  2. ジャバスクリプト

[解決済み】2つの座標間の距離を計算する関数

2022-04-06 02:17:11

質問

現在、下記のような機能を使っていますが、うまく動作しません。Googleマップによると これらの座標 (から)。 59.3293371,13.4877472 から 59.3225525,13.4619422 ) は 2.2 キロメートルであるのに対して、この関数は 1.6 キロメートルです。どうすればこの関数が正しい距離を返すようになるのでしょうか?

function getDistanceFromLatLonInKm(lat1, lon1, lat2, lon2) {
  var R = 6371; // Radius of the earth in km
  var dLat = deg2rad(lat2-lat1);  // deg2rad below
  var dLon = deg2rad(lon2-lon1); 
  var a = 
    Math.sin(dLat/2) * Math.sin(dLat/2) +
    Math.cos(deg2rad(lat1)) * Math.cos(deg2rad(lat2)) * 
    Math.sin(dLon/2) * Math.sin(dLon/2)
    ; 
  var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a)); 
  var d = R * c; // Distance in km
  return d;
}

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

jsFiddleです。 http://jsfiddle.net/edgren/gAHJB/

解決方法は?

あなたが使っているのは ハバーシンの公式 球面上の2点間の距離を計算します。 まゆにつばをつける . Googleマップのリンクでは、直線ではないため、2.2kmと表示されています。

Wolfram Alphaは地理的な計算をするのに最適なリソースであり、また、その距離は この2点間の距離は1.652km .

直線距離を求めるのであれば、この関数は正しく動作しています。 もしあなたが欲しいものが運転距離(または自転車距離、公共交通機関の距離、歩行距離)であれば、マッピングAPI ( グーグル または ビング をクリックすると、適切なルートが表示され、そのルートには距離も表示されます。

ちなみに、Google Maps APIでは、球面距離のパッケージ化されたメソッドとして google.maps.geometry.spherical 名前空間 (を探します。 computeDistanceBetween ). おそらく、自分で作成するよりもよいでしょう(まず、地球の半径についてより正確な値を使用しています)。

ちなみに、「直線距離」というのは、「球面上の直線」のことで、もちろん「曲線」(大円距離)である。