/**
* 经纬度转换成三角函数中度分表形式。
* @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;
}
百度地图 - 两点坐标计算 - JavaScript
最新推荐文章于 2023-12-19 13:46:06 发布