我有一个函数来计算我从Google Maps API获得的两组纬度和经度坐标之间的距离
这是计算距离函数:
function getDistance(lat1, lon1, lat2, lon2) {
var lat1p = parseFloat(lat1);
var lon1p = parseFloat(lon1);
var lat2p = parseFloat(lat2);
var lon2p = parseFloat(lon2);
var R = 6371; // km (change this constant to get miles)
var dLat = (lat2p-lat1p) * Math.PI / 180;
var dLon = (lon2p-lon1p) * Math.PI / 180;
var a = Math.sin(dLat/2) * Math.sin(dLat/2) +
Math.cos(lat1 * Math.PI / 180 ) * Math.cos(lat2 * Math.PI / 180 ) *
Math.sin(dLon/2) * Math.sin(dLon/2);
var c = 2 * Math.atan2(Math.sqrt(a), Math.sqrt(1-a));
var d = R * c;
if (d>1) return Math.round(d)+"km";
else if (d<=1) return Math.round(d*1000)+"m";
return d;
}
我相信所有坐标都被认为是Float类型我不是100%肯定但是当我打印或警告距离是什么时它返回NaN ....有没有办法做到这一点。我试图偏离Google Maps API来计算距离,因为这会让一切变得更难,因为我基本上不得不重新开始。
答案 0 :(得分:1)
我很抱歉我修好了我是双重声明变量以及我有一个。而不是a,当我调用距离函数时。谢谢你们的建议他们让我弄明白了。