各大坐标系统的关系以及在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

在线查询经纬度

相关推荐
wuhen_n1 天前
TypeScript 深度加持:让你的组合式函数拥有“钢筋铁骨”
前端·javascript·vue.js
滕青山1 天前
基于 ZXing 的 Vue 在线二维码扫描器实现
前端·javascript·vue.js
Kayshen1 天前
我在设计工具里实现了一个 Agent Team:多智能体协作生成 UI 的实战经验
前端·aigc·agent
swipe1 天前
深入理解 JavaScript 中的 this 绑定机制:从原理到实战
前端·javascript·面试
Json_Lee1 天前
2026 年了,多 Agent 编码该怎么选?agent-team vs Claude Agent Teams vs Claude Squad vs Met
前端·后端·vibecoding
Novlan11 天前
Stepper 小数输入精度丢失 Bug 修复
前端
陈随易1 天前
刚上市就断货?如此火爆的编程显示器到底有什么魔力
前端·后端·程序员
兆子龙1 天前
前端哨兵模式(Sentinel Pattern):优雅实现无限滚动加载
前端·javascript·算法
豆苗学前端1 天前
彻底讲透浏览器渲染原理,吊打面试官
前端·javascript·面试
踩着两条虫1 天前
AI 驱动的 Vue3 应用开发平台 入门指南(五):创建 H5 移动应用
前端·vue.js·ai编程