美文网首页Python时空大数据前端资源移动互联网
国内各地图API坐标系统比较与转换(做LBS的朋友请转)

国内各地图API坐标系统比较与转换(做LBS的朋友请转)

作者: 评评分分 | 来源:发表于2015-10-27 13:35 被阅读13492次
    开发LBS的朋友看看

    一、各个坐标系的概况

    众所周知地球是一个不规则椭圆体,GIS中的坐标系定义由基准面和地图投影两组参数确定,而基准面的定义则由特定椭球体及其对应的转换参数确定。 基准面是利用特定椭球体对特定地区地球表面的逼近,因此每个国家或地区均有各自的基准面。基准面是在椭球体基础上建立的,椭球体可以对应多个基准面,而基准面只能对应一个椭球体。意思就是无论是谷歌地图、搜搜地图还是高德地图、百度地图区别只是针对不同的大地地理坐标系标准制作的经纬度,不存在准不准的问题,大家都是准的只是参照物或者说是标准不一样。谷歌地图采用的是WGS84地理坐标系(中国范围除外),谷歌中国地图和搜搜中国地图采用的是GCJ02地理坐标系,百度采用的是BD09坐标系,而设备一般包含GPS芯片或者北斗芯片获取的经纬度为WGS84地理坐标系,为什么不统一用WGS84地理坐标系这就是国家地理测绘总局对于出版地图的要求,出版地图必须符合GCJ02坐标系标准了,也就是国家规定不能直接使用WGS84地理坐标系。所以定位大家感觉不准确很多又叫出版地图为火星地图其实只是坐标系不一样而已。这就是为什么设备采集的经纬度在地图上显示的时候经常有很大的偏差,远远超出民用GPS 10米偏移量的技术规范。

    以上参考自:haotsp.com

    总结:

    WGS84坐标系:即地球坐标系,国际上通用的坐标系。

    GCJ02坐标系:即火星坐标系,WGS84坐标系经加密后的坐标系。

    BD09坐标系:即百度坐标系,GCJ02坐标系经加密后的坐标系。

    搜狗坐标系、图吧坐标系等,估计也是在GCJ02基础上加密而成的。


    二、各个地图API采用的坐标系

    API坐标系

    百度地图API百度坐标

    腾讯搜搜地图API火星坐标

    搜狐搜狗地图API搜狗坐标*

    阿里云地图API火星坐标

    图吧MapBar地图API图吧坐标

    高德MapABC地图API火星坐标

    灵图51ditu地图API火星坐标

    注1:百度地图使用百度坐标,支持从地球坐标和火星坐标导入成百度坐标,但无法导出。并且批量坐标转换一次只能转换20个(待验证)。

    注2:搜狗地图支持直接显示地球坐标,支持地球坐标、火星坐标、百度坐标导入成搜狗坐标,同样,搜狗坐标也无法导出。

    个人认为:采用自家坐标体系,而不采用国内通用的火星坐标体系,实在是自寻短处。当然,百度是因为做的足够大、足够好,所以很霸道,也为以后一统天下而不让别人瓜分之而做准备吧。搜狗虽然用自家坐标体系,但能将地球坐标直接导入,此举也属唯一。而图吧地图不知道学什么加密方式,以前用地球坐标用的好好的,现在用图吧自己的坐标,难道是因为给百度做过所以也来了这么一招?或者沿用百度?不得而知。

    本文的目的在于:做地图开发的时候,不希望被一家地图API迁就,所以采用火星坐标是正确的选择,希望本文能够对选择使用谁家API的开发者提供一点帮助吧。就我个人而言,我绝不会使用非火星坐标系统的地图API,虽然百度地图API很好很强大确实很吸引我。

    以上参考自:http://rovertang.com/labs/map-compare/


    三、各个坐标系的相互转换

    1.火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换算法,其中bd_encrypt将 GCJ-02 坐标转换成 BD-09 坐标,bd_decrypt反之。


    2.地球坐标系 (WGS-84) 到火星坐标系 (GCJ-02) 的转换算法

    WGS-84 到 GCJ-02 的转换(即 GPS 加偏)算法

    以上参考自:http://www.xue5.com/Mobile/iOS/679842.html


    3.百度在线转换API

    请求之后会返回一串Json

    什么情况,经纬度居然还加密?那接下来也只好见招拆招了

    到这里也差不多好了,主要的代码都写出来了,其他的您就自己写吧。

    以上参考自:http://scalpel.me/archives/136/


    四、重点啊,原来百度有内置转换方法,这下可以不局限于百度定位SDK了

    在百度地图中取得WGS-84坐标,调用如下方法:

    BMapManager.getLocationManager().setLocationCoordinateType(MKLocationManager.MK_COORDINATE_WGS84);

    这样从百度api中取得的坐标就是WGS-84了,可是这种坐标如果显示到百度地图上就会偏移,也就是说取出一个坐标,原封不动的显示上去就偏移了,所以为了显示也是正常就需要在绘制到百度地图上之前转换成BD-09。

    转换成BD-09,调用方法:

    GeoPoint wgs84;

    GeoPoint bd09 = CoordinateConvert.bundleDecode(CoordinateConvert.fromWgs84ToBaidu(wgs84));

    这里实在不明白为何要设计成CoordinateConvert.fromWgs84ToBaidu(wgs84)返回了一个Bundle,所以还需要CoordinateConvert.bundleDecode()再转成GeoPoint。


    IOS端进行的转换



    推荐阅读:

    Facebook Paper使用的第三方库(强烈推荐)

    iOS/Mac 开发博客列表(不断更新中)

    作为一个iOS开发要看的网站,一定对你有用的,相信我!

    提高iOS开发效率的方法和工具

    IM系统架构设计之浅见

    nil、Nil、NULL和NSNull的理解

    相关文章

      网友评论

      • 奋斗的犇犇:为啥没有火星坐标转大地坐标
      • _老徐_:偷懒找到了一个链接,把其他坐标转换为 高德坐标 :smile: http://lbs.amap.com/api/webservice/guide/api/convert/
        _老徐_:@哪天幸福醒来 谢谢😁
        d07e1834a502:问题已经解决!十分感谢
        d07e1834a502:小哥:你可以,相当6666
      • 星火燎原RTM:有时候不想用其他SDK
        用系统自带的getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
        获取到的数据一般时地球坐标的...
        但是好像有些rom是返回火星坐标 某些自改的rom会用上高德的网络定位服务
        直接返回火星坐标系 现在蛋疼的是
        市面上一些rom返回的是地球坐标 我们开发者纠偏一下就好了
        但是有一些是火星坐标 马蛋再纠偏就错了
        然而没有办法分辨获得的坐标是不是地球坐标还是火星坐标
      • 19f99244faed:云里雾里
      • Stony:火星坐标不是准不准的问题,而是非线性的……被人为加入了一个非线性的偏差,不同地区不一样,相近地区基本一致,但分界位置是断开的。

      本文标题:国内各地图API坐标系统比较与转换(做LBS的朋友请转)

      本文链接:https://www.haomeiwen.com/subject/twuxhttx.html