腾讯地图和百度地图经纬度的相互转换
在小程序中经常会有地图的需求,获取导航的时候,腾讯地图返回的经纬度和百度地图返回的经纬度会有偏差,这时候需要转换下。
/** * 返回两个经纬度之间的距离 * @param {string} lat1 起点纬度 * @param {string} lng1 起点经度 * @param {string} lat2 终点纬度 * @param {string} lng2 终点经度 * @return {string} 返回两个经纬度之间的距离 */ const 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 */ const 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 { lat: lat, lng: lng, } } /** * 腾讯地图转百度地图经纬度 * @param {Number} lat * @param {Number} lng * @returns */ const txMapToBdMap = (lat, lng) => { 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 { lat: lats, lng: lngs, } }