js百度地图计算两经纬度坐标点的距离
百度地图提供现成的方法,直接调用就可以了
Map类
getDistance(start:Point,end:Point) Number 返回两点之间的距离,单位是米。 (自 1.1 新增)
var map = new BMap.Map("container");
var point1 = new BMap.Point(lng1,lat1);
var point2 = new BMap.Point(lng2,lat2);
var distance = map.getDistance(point1,point2);
百度地图用的算法,应该就是球面距离的算法(大圆劣弧的距离),用的余弦函数,
百度地图开放平台 | 百度地图API SDK | 地图开发
自定义的方案: (注意经纬度的坐标系,百度是自己的纬度的坐标系,注意转换)
//计算两点之间直线距离
const algorithm = (point1, point2)=> {
let [x1, y1] = point1;
let [x2, y2] = point2;
let Lat1 = rad(x1); // 纬度
let Lat2 = rad(x2);
let a = Lat1 - Lat2;// 两点纬度之差
let b = rad(y1) - rad(y2); // 经度之差
let s = 2 * Math.asin(Math.sqrt(Math.pow(Math.sin(a / 2), 2)
+ Math.cos(Lat1) * Math.cos(Lat2) * Math.pow(Math.sin(b / 2), 2)));
// 计算两点距离的公式
s = s * 6378137.0;// 弧长等于弧度乘地球半径(半径为米)
s = Math.round(s * 10000) / 10000;// 精确距离的数值
return s;
}
// 角度转换成弧度
const rad =(d) =>{
return d * Math.PI / 180.00;
};
浙公网安备 33010602011771号