详解js根据百度地图提供经纬度计算两点距离


Posted in Javascript onMay 13, 2019

正常在使用百度地图时,我们可以通过BMap的实例对象提供的方法计算距离:

var map = new BMap.Map('map_canvas');
map.getDistance(point1 ,point2);
//point1、point2 是Point对象

如果在不使用百度地图,但是已知百度地图的经纬度情况下也是可以计算出与上面相同的值的

三方库 此库提供计算两点距离的方法

引用此库使用 返回(米)

BMapLib.GeoUtils.getDistance(point1 ,point2)

当然如果只想计算距离也可以直接用下面的代码:

注:BMap需要导入,使用如下:

BMapLib.GeoUtils.getDistance(lng1,lat1,lng2,lat2)

import BMap from 'BMap'
 
var BMapLib = window.BMapLib = BMapLib || {};
 (function() {
 
     /**
      * 地球半径
      */
     var EARTHRADIUS = 6370996.81;
 
     /**
      * @exports GeoUtils as BMapLib.GeoUtils
      */
     var GeoUtils =
       /**
      * GeoUtils类,静态类,勿需实例化即可使用
      * @class GeoUtils类的<b>入口</b>。
      * 该类提供的都是静态方法,勿需实例化即可使用。
      */
     BMapLib.GeoUtils = function(){
 
       };
 
     /**
      * 将度转化为弧度
      * @param {degree} Number 度
      * @returns {Number} 弧度
      */
     GeoUtils.degreeToRad = function(degree){
         return Math.PI * degree/180;
       }
 
     /**
      * 将v值限定在a,b之间,纬度使用
      */
     function _getRange(v, a, b){
         if(a != null){
            v = Math.max(v, a);
           }
         if(b != null){
            v = Math.min(v, b);
           }
         return v;
       }
 
     /**
     * 将v值限定在a,b之间,经度使用
     */
     function _getLoop(v, a, b){
         while( v > b){
            v -= b - a
           }
         while(v < a){
            v += b - a
           }
         return v;
       }
   /**
    * 计算两点之间的距离,两点坐标必须为经纬度
    * @param {lng1} Number 点对象
    * @param {lat1} Number 点对象
    * @param {lng2} Number 点对象
    * @param {lat2} Number 点对象
    * @returns {Number} 两点之间距离,单位为米
    */
     GeoUtils.getDistance = function(lng1, lat1, lng2 ,lat2){
         let point1 = new BMap.Point(parseFloat(lng1) ,parseFloat(lat1));
         let point2 =new BMap.Point(parseFloat(lng2) ,parseFloat(lat2));
         //判断类型
         if(!(point1 instanceof BMap.Point) ||
             !(point2 instanceof BMap.Point)){
             return 0;
           }
         point1.lng = _getLoop(point1.lng, -180, 180);
         point1.lat = _getRange(point1.lat, -74, 74);
         point2.lng = _getLoop(point2.lng, -180, 180);
         point2.lat = _getRange(point2.lat, -74, 74);
         let x1, x2, y1, y2;
         x1 = GeoUtils.degreeToRad(point1.lng);
         y1 = GeoUtils.degreeToRad(point1.lat);
         x2 = GeoUtils.degreeToRad(point2.lng);
         y2 = GeoUtils.degreeToRad(point2.lat);
         return EARTHRADIUS * Math.acos((Math.sin(y1) * Math.sin(y2) + Math.cos(y1) * Math.cos(y2) * Math.cos(x2 - x1)));
       }
})();

以上所述是小编给大家介绍的js根据百度地图提供经纬度计算两点距离详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS 页面内容搜索,类似于 Ctrl+F功能的实现代码
Aug 13 Javascript
几个常用的JavaScript字符串处理函数 - split()、join()、substring()和indexOf()
Jun 02 Javascript
javascript 多种搜索引擎集成的页面实现代码
Jan 02 Javascript
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
Jul 04 Javascript
基于Jquery+Ajax+Json实现分页显示附效果图
Jul 30 Javascript
node.js中的fs.closeSync方法使用说明
Dec 17 Javascript
JavaScript中的Math.LN2属性用法详解
Jun 12 Javascript
JavaScript中 this 指向问题深度解析
Feb 21 Javascript
vue 2.5.1 源码学习 之Vue.extend 和 data的合并策略
Jun 04 Javascript
vue+element 模态框表格形式的可编辑表单实现
Jun 07 Javascript
原生JS实现音乐播放器的示例代码
Feb 25 Javascript
vue自定义右键菜单之全局实现
Apr 09 Vue.js
解决前后端分离 vue+springboot 跨域 session+cookie失效问题
May 13 #Javascript
Vue.js@2.6.10更新内置错误处机制Fundebug同步支持相应错误监控
May 13 #Javascript
详解async/await 异步应用的常用场景
May 13 #Javascript
轻松解决JavaScript定时器越走越快的问题
May 13 #Javascript
JavaScript Math对象和调试程序的方法分析
May 13 #Javascript
jsonp跨域获取百度联想词的方法分析
May 13 #Javascript
基于Fixed定位的框选功能的实现代码
May 13 #Javascript
You might like
php in_array 函数使用说明与in_array需要注意的地方说明
2010/04/13 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
有道JavaScript监听浏览器的问题
2010/06/23 Javascript
HTML5附件拖拽上传drop &amp; google.gears实现代码
2011/04/28 Javascript
IE与FireFox中的childNodes区别
2011/10/20 Javascript
一个背景云变换js特效 鼠标移动背景云变化
2012/12/28 Javascript
A标签中通过href和onclick传递的this对象实现思路
2013/04/19 Javascript
用jquery实现的一个超级简单的下拉菜单
2014/05/18 Javascript
jQuery+Ajax实现无刷新分页
2015/10/30 Javascript
jQuery实现的鼠标滑过弹出放大图片特效
2016/01/08 Javascript
鼠标悬停小图标显示大图标
2016/01/22 Javascript
把多个JavaScript函数绑定到onload事件处理函数上的方法
2016/09/04 Javascript
Bootstrap路径导航与分页学习使用
2017/02/08 Javascript
jq stop()和:is(:animated)的用法及区别(详解)
2017/02/12 Javascript
JavaScript使用math.js进行精确计算操作示例
2018/06/19 Javascript
vue-cli 2.*中导入公共less文件的方法步骤
2018/11/22 Javascript
node.js 如何监视文件变化
2020/09/01 Javascript
JavaScript事件循环及宏任务微任务原理解析
2020/09/02 Javascript
python实现的防DDoS脚本
2011/02/08 Python
Python查询阿里巴巴关键字排名的方法
2015/07/08 Python
python学生信息管理系统
2018/03/13 Python
python实现一个函数版的名片管理系统过程解析
2019/08/27 Python
给Django Admin添加验证码和多次登录尝试限制的实现
2020/07/26 Python
谈一谈HTML5本地存储技术
2016/03/02 HTML / CSS
The North Face北面英国官网:美国著名户外品牌
2017/12/13 全球购物
优瑞自动咖啡机官网:Jura
2018/09/29 全球购物
什么是smarty? Smarty的优点是什么?
2013/08/11 面试题
演讲比赛获奖感言
2014/02/02 职场文书
大学毕业感言200字
2014/03/09 职场文书
应届大专生自荐书
2014/06/16 职场文书
孕妇离婚协议书范本
2014/11/20 职场文书
追悼会答谢词
2015/01/05 职场文书
2015年音乐教师个人工作总结
2015/05/20 职场文书
创业计划书之游泳馆
2019/09/16 职场文书
送给自己的励志语句:要安静的优秀,悄无声息的坚强
2019/11/26 职场文书
mysql使用 not int 子查询隐含陷阱
2022/04/12 MySQL