0

我有一个函数来计算从 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;
}

我相信所有坐标都被认为是浮点类型我不是 100% 确定,但是当我打印或警告它返回 NaN 的距离时......有没有办法做到这一点。我试图远离 Google Maps API 来计算距离,因为这会使一切变得更加困难,因为我基本上必须重新开始。

4

1 回答 1

1

对不起,我修复了它我双重声明变量以及我有一个 . 而不是 a ,当我调用距离函数时。谢谢你们的建议,他们让我弄清楚了。

于 2013-02-17T22:08:54.930 回答