Haversine公式を使用して、2つの緯度経度ペアからの距離を計算しています。地球儀上の移動後の最終緯度経度を求める
function getDistanceFromLatLonInKm(lat1,lon1,lat2,lon2) {
var R = 6371; // Radius of the earth in km
var dLat = deg2rad(lat2-lat1);
var dLon = deg2rad(lon2-lon1);
var lat1 = deg2rad(lat1);
var lat2 = deg2rad(lat2);
var a =
Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.sin(dLon/2) * Math.sin(dLon/2) *
Math.cos(lat1) * Math.cos(lat2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
var d = R * c;
return d;
}
(LAT1、LAT2)出発点を考えると、直線と角度に移動させるのに必要な距離は、私は(LAT2とlon2のように)エンドポイントを決定する必要があります。あなたが水平移動している場合、あなたはdistance/(R * cos(lat))
で経度をインクリメントすることができます
function getFinalLatLon(lat1, lon1, distance, angle) {
var R = 6371; // Radius of the earth in km
var c = distance/R;
// Math.atan2(Math.sqrt(a), Math.sqrt(1-a)) = c/2
var a = // stuck here
// looking for this part of the code
return [lat2, lon2];
}
'Math.atan2'の逆数ですか?あなたは...「Math.tan」? – meowgoesthedog
いいえ...そのMath.atan2 – TechyTimo
つまり、 'Math.atan2'の逆数はそれ自体ですか?私はここで面白くしようとしているわけではありませんが、問題のステートメント(とタイトル)はちょっと混乱しています。 – meowgoesthedog