js百度地图计算两经纬度坐标点的距离

百度地图提供现成的方法,直接调用就可以了

Map类

getDistance(start:Point,end:Point) Number 返回两点之间的距离,单位是米。 (自 1.1 新增)

1
2
3
4
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 | 地图开发 

 

 

 自定义的方案: (注意经纬度的坐标系,百度是自己的纬度的坐标系,注意转换)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
//计算两点之间直线距离
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;
};

  

 

posted @   porter_代码工作者  阅读(840)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
历史上的今天:
2017-05-26 微软Holographic将更名为Windows Mixed Reality
2015-05-26 cocos2dx addchild坐标问题
点击右上角即可分享
微信分享提示