文章目录

  • 前言
  • 一、坐标系
    • 1.地球坐标 (WGS84)
    • 2.国测局坐标系(GCJ-02、火星坐标系)
    • 3.百度坐标(BD-09)
    • 4.国家大地2000坐标系(CGCS2000)
  • 二、百度坐标系(BD-09) 与火星坐标系(GCJ-02)的转换
    • 1.核心代码
    • 2.转换验证
      • 百度地图
      • 高德地图
      • 腾讯地图
  • 三、火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换
  • 四、wgs84坐标转换
    • 1.坐标偏移和经纬度单独转换
    • 2.GCJ02 转换为 WGS84
    • 3.WGS84转GCj02
    • 4.WGS84 百度坐标系 (BD-09) 的转换
    • 5.百度坐标系 (BD-09) WGS84 的转换
  • 总结

前言

地理信息系统 (GIS) 是一个创建、管理、分析和绘制所有类型数据的系统。GIS 将数据连接到地图,将位置数据(事物所在位置)与所有类型的描述性信息(事物在该位置的情况)集成到一起。这可以为适用于自然科学和几乎所有行业的制图和分析提供基础。GIS 帮助用户了解模式、关系和地理环境。其优势包括改善沟通、提高效率以及更好地管理和决策。


一、坐标系

坐标系是一种用于表示地理要素、影像和观察值位置的参照系统,为定义真实世界的位置提供了框架。

使用 [经度,纬度]来描述点的横纵坐标,经度(longitude)范围是[-180,180],纬度(latitude)范围是[-90,90],那么大于90或者小于90的一定不会是纬度,另外我们中国所覆盖的范围大约是经度73.66 ~ 135.05,纬度3.86 ~ 53.55,因此在国内项目上可以通过坐标范围来判定经纬度顺序:经度缩写为lng,纬度缩写为lat。

1.地球坐标 (WGS84)

  • 国际标准,从 GPS 设备中取出的数据的坐标系。
  • 国际地图提供商使用的坐标系(谷歌地图国外、osm、mapbox)。

2.国测局坐标系(GCJ-02、火星坐标系)

  • 中国标准,从国行移动设备中定位获取的坐标数据使用这个坐标系;
  • 国家规定:国内出版的各种地图系统(包括电子形式),必须至少采用GCJ-02对地理位置进行首次加密(高德地图、腾讯地图等) ;
  • WGS84基础上的加密;

3.百度坐标(BD-09)

  • 百度标准,百度 SDK,百度地图,百度GeoCoding 使用;
  • GCJ-02基础上的二次加密。

4.国家大地2000坐标系(CGCS2000)

  • 国家天地图使用的坐标系。
  • 基本跟WGS84相近(厘米级)。

WGS84 通过国测局一次加密偏移后为 GCJ02(国测局2002)坐标系,BD09在此基础上进行了二次加密,而国家大地2000(CGCS2000)则是我们国家目前在推的标准规范平时精度要求不高,我们可以约等同于 WGS84。

二、百度坐标系(BD-09) 与火星坐标系(GCJ-02)的转换

1.核心代码

"""*百度坐标系(BD-09) 与火星坐标系(GCJ-02)的转换*即百度转谷歌(国内)、高德、腾讯* @ parambd_lon* @ parambd_lat* @ returns{*[]}
"""
def bd09togcj02(bd_lon, bd_lat):x = bd_lon - 0.0065y = bd_lat - 0.006z = math.sqrt(x * x + y * y) - 0.00002 * math.sin(y * x_PI)theta = math.atan2(y, x) - 0.000003 * math.cos(x * x_PI)gg_lng = z * math.cos(theta)gg_lat = z * math.sin(theta)return [gg_lng, gg_lat]# print(bd09togcj02(120.199672, 30.331184))

2.转换验证

通过百度、高德和腾讯,国内3大主流LBS地图为测试蓝本,拾取百度坐标后,进行转换到各自版本做标注比对。

百度地图

120.199672,30.331184

高德地图

120.19312059585862, 30.325466905933578

腾讯地图

30.325466905933578, 120.19312059585862。腾讯地图的经纬度输入方式,和百度高德的不同,需要对调位置。

三、火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换

核心代码

"""* 火星坐标系 (GCJ-02) 与百度坐标系 (BD-09) 的转换* 即谷歌、高德 转 百度* @param lng* @param lat* @returns {*[]}
"""def gcj02tobd09(lng, lat):z = math.sqrt(lng * lng + lat * lat) + 0.00002 * math.sin(lat * x_PI)theta = math.atan2(lat, lng) + 0.000003 * math.cos(lng * x_PI)bd_lng = z * math.cos(theta) + 0.0065bd_lat = z * math.sin(theta) + 0.006return [bd_lng, bd_lat]# print(gcj02tobd09(120.19312059585862, 30.325466905933578))

四、wgs84坐标转换

1.坐标偏移和经纬度单独转换

"""* 判断是否在国内,不在国内则不做偏移* @param lng* @param lat* @returns {boolean}
"""def out_of_china(lng, lat):# 纬度3.86~53.55,经度73.66~135.05if 73.66 < lng < 135.05 and 3.86 < lat < 53.55:return False"""* 经纬度偏移转换
"""def transform_lat(lng, lat):ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + 0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))ret += (20.0 * math.sin(6.0 * lng * PI) + 20.0 * math.sin(2.0 * lng * PI)) * 2.0 / 3.0ret += (20.0 * math.sin(lat * PI) + 40.0 * math.sin(lat / 3.0 * PI)) * 2.0 / 3.0ret += (160.0 * math.sin(lat / 12.0 * PI) + 320 * math.sin(lat * PI / 30.0)) * 2.0 / 3.0return retdef transform_lng(lng, lat):ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + 0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))ret += (20.0 * math.sin(6.0 * lng * PI) + 20.0 * math.sin(2.0 * lng * PI)) * 2.0 / 3.0ret += (20.0 * math.sin(lng * PI) + 40.0 * math.sin(lng / 3.0 * PI)) * 2.0 / 3.0ret += (150.0 * math.sin(lng / 12.0 * PI) + 300.0 * math.sin(lng / 30.0 * PI)) * 2.0 / 3.0return ret

2.GCJ02 转换为 WGS84

"""* GCJ02 转换为 WGS84* @param lng* @param lat* @returns {*[]}
"""def gcj02_to_wgs84(lng, lat):# 判断是否为国外坐标if out_of_china(lng, lat):return [lng, lat]else:dlat = transform_lat(lng - 105.0, lat - 35.0)dlng = transform_lng(lng - 105.0, lat - 35.0)radlat = lat / 180.0 * PImagic = math.sin(radlat)magic = 1 - ee * magic * magicsqrtmagic = math.sqrt(magic)dlat = (dlat * 180.0) / ((aa * (1 - ee)) / (magic * sqrtmagic) * PI)dlng = (dlng * 180.0) / (aa / sqrtmagic * math.cos(radlat) * PI)mglat = lat + dlatmglng = lng + dlngreturn [lng * 2 - mglng, lat * 2 - mglat]

3.WGS84转GCj02

"""* WGS84转GCj02* @param lng*  @param lat*  @returns {*[]}
"""def wgs84_to_gcj02(lng, lat):if out_of_china(lng, lat):return [lng, lat]else:dlat = transform_lat(lng - 105.0, lat - 35.0)dlng = transform_lng(lng - 105.0, lat - 35.0)radlat = lat / 180.0 * PImagic = math.sin(radlat)magic = 1 - ee * magic * magicsqrtmagic = math.sqrt(magic)dlat = (dlat * 180.0) / ((aa * (1 - ee)) / (magic * sqrtmagic) * PI)dlng = (dlng * 180.0) / (aa / sqrtmagic * math.cos(radlat) * PI)mglat = lat + dlatmglng = lng + dlngreturn [mglng, mglat]

4.WGS84 百度坐标系 (BD-09) 的转换

"""*WGS84 百度坐标系 (BD-09) 的转换*@param lng*@param lat*@returns {*[]}
"""def wgs84_to_bd09(lng, lat):point = wgs84_to_gcj02(lng, lat)bdpoint = gcj02_to_bd09(point[0], point[1])return [bdpoint[0], bdpoint[1], point[0], point[1]]

5.百度坐标系 (BD-09) WGS84 的转换

"""* 百度坐标系 (BD-09) WGS84 的转换* @param lng* @param lat* @returns {*[]}
"""def bd09_to_wgs84(lng, lat):point = bd09_to_gcj02(lng, lat)wgs84point = gcj02_to_wgs84(point[0], point[1])return [wgs84point[0], wgs84point[1]]

总结

  • 解决使用百度webAPI坐标转换时的问题:X→GPS根据法律规定,不支持将任何类型的坐标转换为GPS坐标;
  • 经纬度精准度和转换时估算的差异,会导致不同坐标在地图标注的差异,对实际地点的标注影响不大;
  • 在实际开发中的产品应用:批量转化。即开发批量转化工具,减少对百度或高德地图限额的依赖。

@漏刻有时

GIS数据格式坐标转换(地球坐标WGS84、GCJ-02、火星坐标、百度坐标BD-09、国家大地坐标系CGCS2000)相关推荐

  1. 百度坐标(BD09)、国测局坐标(火星坐标,GCJ02)、和WGS84坐标系互转

    为什么写这个模块 随着移动互联网的兴起,几乎每一个app都会去收集用户位置,如果恰好你在处理与地理定位相关的代码,并且不了解地理坐标系的话,肯定要被我大天朝各种坐标系搞晕.写这个模块的目的也是因为项目 ...

  2. 2000坐标系xy坐标几位_2000国家大地坐标系转换演示及实践应用专题培训研讨班...

    各相关单位: 按照国务院关于推广使用2000国家大地坐标系(CGCS2000)的有关要求,自然资源部(原国土资源部.国家测绘地理信息局)已确定将全面使用2000国家大地坐标系. 为帮助相关从业人员及时 ...

  3. java 坐标转换工具类(很全面哦!wgs84.... gcj02(即火星坐标).... )

    今天给大家分享一个java实现的地图坐标系经纬度转换工具类 /** Copyright (c). All rights reserved.* Use is subject to license ter ...

  4. php 经纬度坐标转换 WGS84、火星坐标 (GCJ-02)、百度坐标 (BD-09)

    项目有gps上报的功能, 由于前端插件问题导致大量gps定位数据转换百度坐标(BD-09)时产生极大偏移, 故需要后端做经纬度坐标转换, 看到一篇java的相关技术帖, 拿来做了修改 Ps: 坐标转换 ...

  5. 火星坐标、百度坐标、WGS84坐标转换代码(JS、python版)

    火星坐标.百度坐标.WGS84坐标转换代码(JS.python版) 一.JS版本源码 github:https://github.com/wandergis/coordTransform /*** C ...

  6. java 火星坐标转wgs84_js中火星坐标、百度坐标、WGS84坐标转换实现方法示例

    本文实例讲述了js中火星坐标.百度坐标.WGS84坐标转换实现方法.分享给大家供大家参考,具体如下: //定义一些常量 var x_PI = 3.14159265358979324 * 3000.0 ...

  7. java 经纬度坐标转换 WGS84、火星坐标 (GCJ-02)、百度坐标 (BD-09)

    会有偏移,但是还能接受 WGS84 国际标准,从 GPS 设备中取出的数据的坐标系 国际地图提供商使用的坐标系 火星坐标 (GCJ-02) 中国标准,从国行移动设备中定位获取的坐标数据使用这个坐标系 ...

  8. 坐标计算距离公式 火星坐标系_根据经纬度计算距离的公式、百度坐标转换成GPS坐标(PHP版)...

    //百度坐标转换成GPS坐标 $lnglat = '121.437518,31.224665'; function FromBaiduToGpsXY($lnglat){ // 经度,纬度 $lngla ...

  9. 【GIS工具】谷歌卫星图下载工具之再聊坐标问题

    按照设想,在poi加载工具之后,围绕三调转换和调研的基础工具就差卫星图了,所以就开始了写这个工具,但各种坐标之间的转换问题一直都没有一个满意的解决办法,先发一个版本,以后再更新! 1.聊UTM坐标系 ...

最新文章

  1. Azure Logic Apps正式发布
  2. Nat. Commun. | AI语言工具揭示分子运动
  3. SRIO学习(五)——SerDes Macro(串行解串宏)
  4. jquery插件学习(六)
  5. hash_map allocator
  6. 用Flash创建一个类似Nano War游戏的教程
  7. MTM:matlab实现3谱功率计算
  8. 最新版飞鸽传书(http://www.freeeim.com)下载
  9. 网抑云熬夜打卡源码+微信登录+免签支付+今日打卡统计
  10. 形式多样!APP引导页设计灵感
  11. Python+sklearn训练结果保存与加载(以垃圾邮件分类为例)
  12. MFC中CString,int,string,char * ,char[] 之间互转
  13. R语言中,保留含有特定字符的元素
  14. 分享一份 sublime 的个人配置文件
  15. NOIP2018 DAY1T1 铺设道路(水题)
  16. vs2013 也能重构(refactor )变量名了
  17. 这几个开源的商城实战项目,良月柒强烈推荐!
  18. Linux常用命令大全
  19. 在 MQL5 中使用 WININET。第二部分:POST 请求和文件
  20. 浅析融媒体的发展现状和未来前景

热门文章

  1. Jupyter Notebook快捷键与python基本语法
  2. CakePHP 2.x CookBook 中文版 第七章 模型 之 删除数据
  3. 多方面浅谈互联网技术
  4. 基于HackRF的AIS信号采集与解调
  5. 零点工作室暑假集训(AtCoder--ABC279)
  6. 第8章 Foundation Kit介绍
  7. mysql数据库blob换行_mysql数据库blob类型
  8. 回音壁与电视扬声器那些不得不说的事
  9. TCP/IP 各层的 数据格式(Segment,Datagram,Packet,ARP 数据包,Frame)
  10. sqlserver命令注入和getshell