各大坐标系统的关系以及在uniapp中的应用

公司的业务涉及到了定位、地图等功能,在了解后发现坐标系也有好几种,这里做个简单总结。

各大坐标系简介及关系

  1. WGS84(World Geodetic System 1984)
  • 国际标准,常用于 GPS 定位。

  • 国际地图提供商使用

  • 在中国地区,直接使用 WGS84 会有一定的偏移(法律规定)。

  1. GCJ-02(火星坐标系)
  • 中国标准,由中国国家测绘局定义,对 WGS84 坐标加入了偏移。

  • 高德地图、腾讯地图等国内地图服务使用 GCJ-02 坐标系。

  1. BD-09(百度坐标系)
  • 在 GCJ-02 的基础上再次加密偏移得到的。

  • 仅百度地图使用

坐标系之间的转换

转换关系:WGS84 -> GCJ-02 -> BD-09

叠甲:转换函数都是问 AI 或者网上复制的,并不是我原创的。

因此没必要再复制一遍,不太尊重原创,这里给出代码的地址:https://github.com/wandergis/coordtransform/blob/master/index.js

在uniapp中的应用

uniapp 官方提供了 API 获取地理位置,uni.getLocation(),默认是 WGS84 坐标,如果需需要 GCJ-02 坐标,修改 type 参数即可,但需要配置SDK。

注意:uniapp 新版本已经取消对百度地图的支持。

简单使用:

js 复制代码
uni.getLocation({
    type: 'wgs84',
    success(res) {
        const gcj02Coords = wgs84ToGcj02(res.longitude, res.latitude);
    }
});

参考

坐标转换工具模块:https://github.com/wandergis/coordtransform

在线查询经纬度

相关推荐
云水一下16 小时前
TypeScript 从零基础到精通(五):高级类型与泛型
前端·javascript·typescript
counterxing17 小时前
vibe coding 之后,我更不想打字了
前端·agent·ai编程
copyer_xyf17 小时前
Python 模块与包的导入导出
前端·后端·python
研☆香17 小时前
es6新特性功能介绍(四)
前端·ecmascript·es6
微扬嘴角17 小时前
React篇1--JSX语法规则、组件、组件实例的3大特性
前端·react.js·前端框架
copyer_xyf17 小时前
Python venv 虚拟环境
前端·后端·python
无聊的老谢18 小时前
Vue 3 + TypeScript 构建大型电信运维平台的前端架构设计
前端·vue.js·typescript
xiaofeichaichai18 小时前
Map / Set / WeakMap / WeakSet
前端·javascript
李可以量化18 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
copyer_xyf19 小时前
Python 如何同时做很多事:进程、线程、协程
前端·后端·python