這篇文章給大家分享的是有關(guān)js如何根據(jù)百度地圖提供經(jīng)緯度計算兩點距離的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都地區(qū)優(yōu)秀IDC服務(wù)器托管提供商(成都創(chuàng)新互聯(lián)公司).為客戶提供專業(yè)的服務(wù)器托管,四川各地服務(wù)器托管,服務(wù)器托管、多線服務(wù)器托管.托管咨詢專線:028-86922220
正常在使用百度地圖時,我們可以通過BMap的實例對象提供的方法計算距離:
var map = new BMap.Map('map_canvas');
map.getDistance(point1 ,point2);
//point1、point2 是Point對象如果在不使用百度地圖,但是已知百度地圖的經(jīng)緯度情況下也是可以計算出與上面相同的值的
三方庫 此庫提供計算兩點距離的方法
引用此庫使用 返回(米)
BMapLib.GeoUtils.getDistance(point1 ,point2)
當然如果只想計算距離也可以直接用下面的代碼:
注:BMap需要導(dǎo)入,使用如下:
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類,靜態(tài)類,勿需實例化即可使用
* @class GeoUtils類的<b>入口</b>。
* 該類提供的都是靜態(tài)方法,勿需實例化即可使用。
*/
BMapLib.GeoUtils = function(){
};
/**
* 將度轉(zhuǎn)化為弧度
* @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之間,經(jīng)度使用
*/
function _getLoop(v, a, b){
while( v > b){
v -= b - a
}
while(v < a){
v += b - a
}
return v;
}
/**
* 計算兩點之間的距離,兩點坐標必須為經(jīng)緯度
* @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)));
}
})();感謝各位的閱讀!關(guān)于“js如何根據(jù)百度地圖提供經(jīng)緯度計算兩點距離”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當前文章:js如何根據(jù)百度地圖提供經(jīng)緯度計算兩點距離
當前地址:http://chinadenli.net/article46/pgpeeg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、移動網(wǎng)站建設(shè)、電子商務(wù)、營銷型網(wǎng)站建設(shè)、軟件開發(fā)、App設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)