百度地图跟高德地图你给他同样一个值,在地图上标记出来的位置时有差异的,起码差好几百米?这是什么问题呢?
特别是现在运用比较广泛的微信中经常会去插入一些地图,但是这个地图系统有点让人头痛,网站制作公司在厦门给大家解释一下,这个到底是什么问题。
美国gps使用的是wgs84的 坐标系统,以经纬度的形式来表示地球平面上的某一个位置,这应该是国际共识。
但在我国,出于国家安全考虑,国内所有导航电子地图必须使用国家测绘局制定的 加密坐标系统,即将一个真实的经纬度坐标加密成一个不正确的经纬度坐标,我们在业内将前者称之为地球坐标,后者称之为火星坐标,具体的说明可以参看百度百 科中关于火星坐标系统的解释。
1.国内各地图api坐标系统比较
参考http://rovertang.com/labs/map-compare/
结论是:
api 坐标系
百度地图api 百度坐标
腾讯搜搜地图api 火星坐标
搜狐搜狗地图api 搜狗坐标*
阿里云地图api 火星坐标
图吧mapbar地图api 图吧坐标
高德mapabc地图api 火星坐标
灵图51ditu地图api 火星坐标
2.下面是百度官方对百度坐标为何有偏移的解释
国际经纬度坐标标准为wgs-84,国内必须至少使用国测局制定的gcj-02,对地理位置进行首次加密。百度坐标在此基础上,进行了bd-09二次加密措施,更加保护了个人隐私。百度对外接口的坐标系并不是gps采集的真实经纬度,需要通过坐标转换接口进行转换。
3.火星坐标系?(gcj-02)?与百度坐标系?(bd-09)?的转换算法
gcj-02(火星坐标)?和?bd-09?(百度坐标)
算法代码如下,其中?bd_encrypt?将?gcj-02?坐标转换成?bd-09?坐标,?bd_decrypt?反之。
void bd_encrypt(double gg_lat, double gg_lon, double &bd_lat, double &bd_lon)
{
double x = gg_lon, y = gg_lat;
double z = sqrt(x * x + y * y) + 0.00002 * sin(y * x_pi);
double theta = atan2(y, x) + 0.000003 * cos(x * x_pi);
bd_lon = z * cos(theta) + 0.0065;
bd_lat = z * sin(theta) + 0.006;
}
void bd_decrypt(double bd_lat, double bd_lon, double &gg_lat, double &gg_lon)
{
double x = bd_lon – 0.0065, y = bd_lat – 0.006;
double z = sqrt(x * x + y * y) – 0.00002 * sin(y * x_pi);
double theta = atan2(y, x) – 0.000003 * cos(x * x_pi);
gg_lon = z * cos(theta);
gg_lat = z * sin(theta);
}
4.地球坐标系?(wgs-84)?到火星坐标系?(gcj-02)?的转换算法
wgs-84?到?gcj-02?的转换(即?gps?加偏)算法是一个普通青年轻易无法接触到的“公开”的秘密。这个算法的代码在互联网上是公开的,详情请使用?google?搜索?“wgtochina_lb”?。
整理后的算法代码请参考?https://on4wp7.codeplex.com/sourcecontrol/changeset/view/21483#353936?。知道了这个算法之后,就可以离线进行?google?地图偏移校正,不必像之前那么麻烦。
至于?gcj-02?到?wgs-84?的转换(即?gps?纠偏),可以使用二分法。