在开始这个题目以前,先给你们再次扫扫盲,扫的不是坐标系统的盲,而是咱们国家所使用的坐标系统。你们都知道,美国GPS使用的是WGS84的坐标系统,以经纬度的形式来表示地球平面上的某一个位置,这应该是国际共识。但在我国,出于国家安全考虑,国内全部导航电子地图必须使用国家测绘局制定的加密坐标系统,即将一个真实的经纬度坐标加密成一个不正确的经纬度坐标,咱们在业内将前者称之为地球坐标,后者称之为火星坐标,具体的说明能够参看百度百科中关于火星坐标系统的解释。html
参考http://rovertang.com/labs/map-compare/算法
结论是:安全
API | 坐标系 |
百度地图API | 百度坐标 |
腾讯搜搜地图API | 火星坐标 |
搜狐搜狗地图API | 搜狗坐标* |
阿里云地图API | 火星坐标 |
图吧MapBar地图API | 图吧坐标 |
高德MapABC地图API | 火星坐标 |
灵图51ditu地图API | 火星坐标 |
国际经纬度坐标标准为WGS-84,国内必须至少使用国测局制定的GCJ-02,对地理位置进行首次加密。百度坐标在此基础上,进行了BD-09二次加密措施,更加保护了我的隐私。百度对外接口的坐标系并非GPS采集的真实经纬度,须要经过坐标转换接口进行转换。post
GCJ-02(火星坐标) 和 BD-09 (百度坐标)google
算法代码以下,其中 bd_encrypt
将 GCJ-02 坐标转换成 BD-09 坐标, bd_decrypt
反之。阿里云
void bd_encrypt(double gg_lat, double gg_lon, double &bd_lat, double &bd_lon)加密
{url
double x = gg_lon, y = gg_lat;spa
double z = sqrt(x * x + y * y) + 0.00002 * sin(y * x_pi);.net
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);
}
WGS-84 到 GCJ-02 的转换(即 GPS 加偏)算法是一个普通青年轻易没法接触到的“公开”的秘密。这个算法的代码在互联网上是公开的,详情请使用 Google 搜索 "wgtochina_lb" 。
整理后的算法代码请参考 https://on4wp7.codeplex.com/SourceControl/changeset/view/21483#353936 。知道了这个算法以后,就能够离线进行 Google 地图偏移校订,没必要像以前那么麻烦。
至于 GCJ-02 到 WGS-84 的转换(即 GPS 纠偏),能够使用二分法。