百度地图的经纬度位置
来源:互联网 发布: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;}
得到的最终结果,其实跟百度距离差别很小。
这样的好处就是,将距离的计算提交给服务器处理,客户端本身不参与计算,也不需要转换百度坐标到实际经纬度。
- 百度地图的经纬度位置
- Android中百度地图计算MapView任意位置的经纬度
- 根据百度地图API,反向获取某个位置的经纬度
- 百度地图API: 通过经纬度定位到百度地图位置
- Android实战--基于位置的服务(获取自己位置的经纬度+百度地图)
- 百度地图,根据地图上任意一点的经纬度获取周边最近的POI位置信息
- 百度地图---获取当前的位置返回的是汉字显示而不是经纬度
- 百度地图获取经纬度和当前精确位置名称
- 利用百度地图通过位置名称查询经纬度方法总结
- 根据指定的经纬度显示地图位置
- 百度地图 经纬度和地理位置的转换
- 关于百度地图的经纬度常用计算方法
- 百度地图--获取对角线的经纬度
- 百度地图:获取地址的经纬度
- 获取百度地图经纬度
- 百度地图定位经纬度
- 百度地图经纬度纠偏
- 百度地图----解析经纬度
- commons-logging 和 log4j 之间的关系
- 关联v4源代码
- http://www.allaboutcookies.org/
- 脏读、不可重复读、幻读
- 面向GC的Java编程
- 百度地图的经纬度位置
- 04 pull生成XML
- E-ROBOT 连接蓝牙自动接听电话,开车时很方便
- dgsdfd
- dataSource配置说明
- Java jdbc数据库连接池总结!
- fhfghf
- Win32下绘图程序(二)保存绘图信息至文件
- 求1—n的全排列