百度地图的经纬度位置

来源:互联网 发布:linux libevent 安装 编辑:程序博客网 时间:2024/05/01 01:50

百度定位SDK可以返回三种坐标系,分别是bd09, bd09ll和gcj02,其中bd09ll能无偏差地显示在百度地图上。

后缀ll=经纬度球面坐标,mc=墨卡托平面坐标。当定位SDK中输入gcj02时,默认为经纬度坐标,输入bd09时,默认为墨卡托平面坐标。

百度对外接口的坐标系,都是经过国家测绘局加密处理,符合国家测绘局对地理信息保密要求。

国际经纬度坐标标准为WGS-84,国内必须至少使用国测局制定的GCJ-02,对地理位置进行首次加密。百度坐标在此基础上,进行了BD-09二次加密措施,更加保护了个人隐私。百度对外接口的坐标系并不是GPS采集的真实经纬度,需要通过坐标转换接口进行转换。


以上为百度官方说明,详见:百度定位坐标问题

简单的说就是:百度经纬度=((处理2)((处理后1)gps)))。

第一次处理为国家为保护地理位置信息安全做出的处理,第二次处理为百度自己做的。


看见没,后四位直接为0了,地理位置比较


百度地图提供了接口,让别人的坐标转换为自己的地理位置,反之的却没有,让开发的人员很头疼。

具体可以阅读:地图位置和坐标



某些时候,我们需要了解到地理位置两点之间的信息,如果有确切的经纬度那还好办,如果是百度地图位置的呢?

我们观察到实际的位置和百度的位置差别不是很大,如果对于精度不是要求严格的话,测距使用地理位置的算法的话,那么效果也差不多的。


采集了3组百度位置:

大概位置是成都周边,在范围上是随机采取的,有城郊也有市区,距离是使用百度sdk得到的。

然后我们在服务器上使用地球坐标距离计算公式(当然,你需要对数据处理下,类似30.684251,104.129661):

function GetDistance($lat1, $lng1, $lat2, $lng2){$EARTH_RADIUS = 6378.137; $a = rad($lat1)- rad($lat2);$b = rad($lng1) - rad($lng2);$s = 2 * asin(sqrt(pow(sin($a/2),2) + cos(rad($lat1))*cos(rad($lat2))*pow(sin($b/2),2)));$s = $s *$EARTH_RADIUS;$s = round($s * 10000) / 10;return $s;}

得到的最终结果,其实跟百度距离差别很小。


这样的好处就是,将距离的计算提交给服务器处理,客户端本身不参与计算,也不需要转换百度坐标到实际经纬度。

0 0
原创粉丝点击