热门标签 | HotTags
当前位置:  开发笔记 > 开放平台 > 正文

百度坐标系(BD-09)与火星坐标系(GCJ-02)的相互转换

***百度坐标系(BD-09)与火星坐标系(GCJ-02)的转换*即百度转谷歌、高德*@param

 

/**
* 百度坐标系 (BD-09) 与 火星坐标系 (GCJ-02)的转换
* 即 百度 转 谷歌、高德
* @param {*} lat 百度纬度
* @param {*} lng 百度经度
*/
const bdTogcj = function( lat, lng) {
  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 g2_lnn = z * Math. cos( theta);
  let g2_lat = z * Math. sin( theta);
  return [ g2_lat, g2_lnn]
}
/**
* 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换
* 即谷歌、高德 转 百度
* @param {*} g2_lat 火星坐标纬度
* @param {*} g2_lng 火星坐标经度
*/
const gcjTobd = function( g2_lat, g2_lng) {
  let x_pi = 3.14159265358979324 * 3000.0 / 180.0;
  let z = Math. sqrt( g2_lng * g2_lng + g2_lat * g2_lat) + 0.00002 * Math. sin( g2_lat * x_pi);
  let theta = Math. atan2( g2_lat, g2_lngg2_lng) + 0.000003 * Math. cos( g2_lng * x_pi);
  let bd_lng = z * Math. cos( theta) + 0.0065;
  let bd_lat = z * Math. sin( theta) + 0.006;
  return [ bd_lng, bd_lat]
}

推荐阅读
author-avatar
程橙屋04_kc275_938
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有