百度地图 - 两点坐标计算 - JavaScript

版权声明:本文为博主原创文章,转载请注明出处:http://blog.csdn.net/deaidai https://blog.csdn.net/deaidai/article/details/83049154
/**
 * 经纬度转换成三角函数中度分表形式。
 * @param {*} d 坐标
 */
function Rad(d) {
    return d * Math.PI / 180.0
}
/**
 * 计算两个坐标之间的距离
 * @param lng1 坐标点1的经度
 * @param lat1 坐标点1的纬度
 * @param lng2 坐标点2的经度
 * @param lat2 坐标点2的纬度
 * @return float
 */
function GetDistance(lng1, lat1, lng2, lat2) {
    let radLat1 = Rad(lat1);
    let radLat2 = Rad(lat2);
    let a = radLat1 - radLat2;
    let b = Rad(lng1) - Rad(lng2);
    let s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2) + Math.cos(radLat1) * Math.cos(radLat2) * Math.pow(Math.sin(b / 2), 2)))
    s = s * 6378.137; // 地球半径,千米;
    s = Math.round(s * 10000) / 10000; // 输出为公里
    // s = Math.round(s * 1000) / 1; // 单位修改为米,取整
    //s=s.toFixed(4);
    return s;
}

猜你喜欢

转载自blog.csdn.net/deaidai/article/details/83049154