DAMO开发者矩阵
计算两个经纬度之间的直线距离
计算两个经纬度之间的直线距离
在社区里看了一下,关于计算经纬的有几个帖子,但是返回值都不正确,或者转换不完整。我经过详细推敲,找到了计算距离完整方法,使用百度地图经纬度即可,特此发帖分享!如有不对的地方还请留言斧正!最后希望斑竹关注、求精!! /** * 计算两点之间距离,返回包含单位的字符串类型(经度放前面一是为了符合中国的使用习惯,二是为了跟appcan的 一些方法保持同样风格)
| 在社区里看了一下,关于计算经纬的有几个帖子,但是返回值都不正确,或者转换不完整。我经过详细推敲,找到了计算距离完整方法,使用百度地图经纬度即可,特此发帖分享! 如有不对的地方还请留言斧正! 最后希望斑竹关注、求精!! ![]() /** * 计算两点之间距离,返回包含单位的字符串类型(经度放前面一是为了符合中国的使用习惯,二是为了跟appcan的 一些方法保持同样风格) * @param lng 经度 * @param lat 纬度 */ this.GetDisance = function(lng1, lat1, lng2, lat2) { // 经典计算方式 if ((Math.abs(lat1) > 90 ) || (Math.abs(lat2) > 90 )) { return "纬度错误"; } if ((Math.abs(lng1) > 180 ) || (Math.abs(lng2) > 180 )) { return "经度错误"; } var radLat1 = rad(lat1); var radLat2 = rad(lat2); var a = radLat1 - radLat2; var b = rad(lng1) - rad(lng2); var 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; // EARTH_RADIUS; 单位Km s = Math.round(s * 10000) / 10000; // 整理显示方式 var result = s * 1000; if (result < 1000) { result = (parseInt(result / 100) + 1) * 100 + "米以内"; } else if (result < 20000) { result = (parseInt(result / 1000) + 1) + "公里以内"; } else { result = "20公里以外" } return result; }; /** * private const double EARTH_RADIUS = 6378.137; */ function rad(d) { return d * Math.PI / 180.0; } |
DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。
更多推荐
- · 【扩展卡尔曼滤波器EKF】基于UWB雷达的SLAM能够在室内环境内映射自然点地标,并改善机器人定位附Matlab代码
- · 【扩展卡尔曼滤波器EKF】基于UWB雷达的SLAM能够在室内环境内映射自然点地标,并改善机器人定位附Matlab代码
- · 【扩展卡尔曼滤波器EKF】基于UWB雷达的SLAM能够在室内环境内映射自然点地标,并改善机器人定位附Matlab代码
6057
1
0
- 0
扫一扫分享内容
分享
回到
顶部
顶部

所有评论(0)