微信小程序里使用的地图api是腾讯地图,而通过腾讯地图获取到的经纬度是不可以直接渲染给百度或高德地图的,因为他们使用的坐标系不同,百度使用的是自称一套的BD09坐标,腾讯高德使用的是GCJ-02坐标
如果直接渲染的话就会出现两个地图中定位点偏差很大的情况
碰到这种情况就需要转换
腾讯高德转百度
function TxMapTransBMap(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
};
// 百度转腾讯高德
function BdMapTransqqMap(lng, lat) {
let x_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 * x_pi);
let theta = Math.atan2(y, x) - 0.000003 * Math.cos(x * x_pi);
let lngs = z * Math.cos(theta);
let lats = z * Math.sin(theta);
return {
longitude: lngs,
latitude: lats
};
}