你好,我正在做一个计算器,找出两点之间的距离。一切正常运转。我只想确保我的数学对计算是正确的。我会给你两个坐标插入,并告诉我是对还是错。谢谢。
测试坐标: lat1:27.95094 lng1:-82.45404
lat2:27.9659 lng2:-82.8001
测试结果:
21.13英里
我只想检查一下,我得到的是从1分到下一个点的正确计算,或者我的数学是否不正确。谢谢。
function distance(lat1, lng1, lat2, lng2, unit) {
var radlat1 = Math.PI * lat1/180;
var radlat2 = Math.PI * lat2/180;
var theta = lng1-lng2;
var radtheta = Math.PI * theta/180;
var dist = Math.sin(radlat1) * Math.sin(radlat2) + Math.cos(radlat1) * Math.cos(radlat2) * Math.cos(radtheta);
if (dist > 1) {
dist = 1;
}
dist = Math.acos(dist);
dist = dist * 180/Math.PI;
dist = dist * 60 * 1.1515;
if (unit=='miles') { dist = (dist * 0.8684) * 1.15077945 }
return dist;
}
travel = distance(lat1, lng1, results.features[0].center[1], results.features[0].center[0], 'miles');
travel = parseInt(travel * 100)/100;
发布于 2022-01-15 16:04:28
是的,您似乎正确地实现了Haversine公式(https://en.wikipedia.org/wiki/Haversine_formula)
https://stackoverflow.com/questions/70722995
复制相似问题