?在小程序中经常会有地图的需求,获取导航的时候,腾讯地图返回的经纬度和百度地图返回的经纬度会有偏差,这时候需要转换下。
/**
* 返回两个经纬度之间的距离
* @param {string} lat1 起点纬度
* @param {string} lng1 起点经度
* @param {string} lat2 终点纬度
* @param {string} lng2 终点经度
* @return {string} 返回两个经纬度之间的距离
*/
function getDistance(lat1, lng1, lat2, lng2) {
function e(lat1, lng1, lat2, lng2) {
lat1 = (lat1 * f) / 180;
lat2 = (lat2 * f) / 180;
lng1 =
2 *
Math.asin(
Math.sqrt(
Math.pow(Math.sin((lat1 - lat2) / 2), 2) +
Math.cos(lat1) *
Math.cos(lat2) *
Math.pow(Math.sin(((lng1 * f) / 180 - (lng2 * f) / 180) / 2), 2),
),
);
return (lng1 = Math.round(6378137 * lng1));
}
let f = Math.PI;
return 1e3 < e(lat1, lng1, lat2, lng2) ? Math.round(e(lat1, lng1, lat2, lng2)) : e(lat1, lng1, lat2, lng2);
}
/**
* 百度地图经纬度转为腾讯地图经纬度
* @param {Number} lat
* @param {Number} lng
* @returns
*/
function bdMapToTxMap(lat, lng) {
let pi = (3.14159265358979324 * 3000.0) / 180.0;
let x = lng - 0.0065;
let y = lat - 0.006;
let z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y * pi);
let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * pi);
lng = z * Math.cos(theta);
lat = z * Math.sin(theta);
return { lng: lng, lat: lat };
}
/**
* 腾讯地图转百度地图经纬度
* @param {Number} lat
* @param {Number} lng
* @returns
*/
function txMapToBdMap(lng, lat) {
let x_pi = (3.14159265358979324 * 3000.0) / 180.0;
let x = lng;
let y = lat;
let z = Math.sqrt(x * x + y * y) + 0.00002 * Math.sin(y * x_pi);
let theta = Math.atan2(y, x) + 0.000003 * Math.cos(x * x_pi);
let lngs = z * Math.cos(theta) + 0.0065;
let lats = z * Math.sin(theta) + 0.006;
return {
lng: lngs,
lat: lats,
};
}
|