腾讯地图和百度地图经纬度的相互转换

在小程序中经常会有地图的需求,获取导航的时候,腾讯地图返回的经纬度和百度地图返回的经纬度会有偏差,这时候需要转换下。

/** * 返回两个经纬度之间的距离
 * @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,
  }
}

 

posted @ 2022-06-29 16:20  时光独醒  阅读(72)  评论(0编辑  收藏  举报