我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Qt如何实现经纬度坐标纠偏

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Qt如何实现经纬度坐标纠偏

本篇内容主要讲解“Qt如何实现经纬度坐标纠偏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Qt如何实现经纬度坐标纠偏”吧!

一、前言

地图应用中都涉及到一个问题就是坐标纠偏的问题,这个问题的是因为根据地方规则保密性要求不允许地图厂商使用标准的GPS坐标,而是要用国家定义的偏移标准,或者在此基础上再做算法运算,所以这就出现了三种常规的坐标标准:GPS坐标(WGS-84,国际标准,谷歌地球软件,硬件GPS模块等)、中国坐标偏移标准(GCJ-02,谷歌地图、腾讯地图、高德地图等)、百度坐标偏移标准(BD-09,仅仅百度地图采用)。由于不允许其他坐标转换成GPS坐标,所以三种坐标互换就剩4种常用转换:GPS转百度、GPS转其他、百度转其他、其他转百度,其他就是中国坐标偏移标准,目前谷歌地图、腾讯地图、高德地图都采用这个标准。

在线百度地图提供了Convertor类专门负责这个转换,只需要调用对应translate方法传入参数即可,这个转换出来的结果比较理想,缺点就是必须在线使用,毕竟算法是存储在服务器上的保密的,但是很多应用场景是离线使用的,这就需要找一个比较准确的算法做这个转换,网上流传的主要是java、c#、python等语言的版本,于是特意将其改写成了c++ Qt的版本,亲测和在线版本的运算结果基本一致,据说赤道附近可能偏差很大,但是在中国地图上偏差很小。

二、功能特点

1 省市区域地图封装类功能特点

  1. 同时支持闪烁点图、迁徙图、区域地图、世界地图、仪表盘等。

  2. 可以设置标题、提示信息、背景颜色、文字颜色、线条颜色、区域颜色等各种颜色。

  3. 可设置城市的名称、值、经纬度 集合。

  4. 可设置地图的放大倍数、是否允许鼠标滚轮缩放。

  5. 内置世界地图、全国地图、省份地图、地区地图,可以精确到县,所有地图全部离线使用。

  6. 内置了各省市json数据文件转js文件功能,如有数据更新自行转换即可,支持单个文件转换和一键转换所有文件。

  7. 内置了从json文件或者js文件获取该区域的所有名称和经纬度信息集合的功能,可以通过该方法获取到信息用来显示。

  8. 依赖浏览器组件显示地图,提供的demo支持webkit/webengine/miniblink/ie 多种方式加载网页。

  9. 采用miniblink浏览器内核打通了Qt5.6及后续版本+mingw编译器缺少浏览器模块的遗憾,使得整个项目支持所有Qt版本,亲测4.7到6.2等任意版本。

  10. 闪烁点迁徙图等设置的点支持单独设置颜色。

  11. 提供接口直接获取点击的点相关信息,方便程序联动处理。

  12. 拓展性极强,可以依葫芦画瓢自行增加各种精美的echarts组件,做出牛逼的效果。

  13. 内置的仪表盘组件提供交互功能,demo演示中包含了对应的代码。

  14. 函数接口友好和统一,使用简单方便,就一个类。

  15. 支持任意Qt版本、任意系统、任意编译器。

2 百度地图封装类功能特点

  1. 同时支持在线地图和离线地图两种模式。

  2. 同时支持webkit内核、webengine内核、miniblink内核、IE内核。

  3. 支持设置多个标注点,信息包括名称、地址、经纬度。

  4. 可设置地图是否可单击、拖动、鼠标滚轮缩放。

  5. 可设置协议版本、秘钥、主题样式、中心坐标、中心城市、地理编码位置等。

  6. 可设置地图缩放比例和级别,缩略图、比例尺、路况信息等控件的可见。

  7. 支持地图交互,比如鼠标按下获取对应位置的经纬度。

  8. 支持查询路线,可设置起点位置、终点位置、路线模式、路线方式、路线方案(最少时间、最少换乘、最少步行、不乘地铁、最短距离、避开高速)。

  9. 可显示点线面工具,可直接在地图上划线、点、矩形、圆形等。

  10. 可设置行政区划,指定某个城市区域绘制图层,在线地图自动输出行政区划边界点集合到js文件给离线地图使用。

  11. 可静态或者动态添加多个覆盖物。支持点、折线、多边形、矩形、圆形、弧线、点聚合等。

  12. 提供函数接口处理经纬度解析成地址和地址解析成经纬度坐标。

  13. 提供的demo直接可以单独选点执行对应的处理比如路线查询。

  14. 可以拿到路线查询到的点坐标信息集合,比如用于机器人坐标导航等。

  15. 封装了丰富的函数比如删除指定点和所有点,删除指定覆盖物和所有覆盖物等。

  16. 标注点弹框信息可以自定义内容,标准html格式。

  17. 标注点单击事件可选 0-不处理 1-自己弹框 2-发送信号。

  18. 标注点可设置动画效果 0-不处理 1-跳动 2-坠落

  19. 标注点可设置本地图片文件等。

  20. 函数接口友好和统一,使用简单方便,就一个类。

  21. 支持js动态交互添加点、删除点、清空点、重置点,不需要刷新页面。

  22. 支持任意Qt版本、任意系统、任意编译器。

3 离线地图下载类功能特点

  1. 多线程同步下载多级别瓦片地图,不卡界面。

  2. 内置多个离线地图下载请求地址,自动随机选择一个发送请求。

  3. 下载地图类型同时支持街道图和卫星图。

  4. 自动计算可视区域或者行政区域的下载瓦片数量。

  5. 下载的级别可以自定义范围和选择。

  6. 每个瓦片下载完成都发送信号通知,参数包括下载用时。

  7. 可设置下载最大超时时间,超过了则丢弃跳到下一个下载任务。

  8. 实时显示下载进度,以及当前级别已经下载的瓦片数和总瓦片数。

  9. 下载过程中可以停止下载,下载完成自动统计总用时。

  10. 内置经纬度和屏幕坐标互相转换函数。

  11. 目前支持百度地图,其他地图比如谷歌地图、腾讯地图、高德地图可以定制。

  12. 函数接口友好和统一,使用简单方便,就一个类。

  13. 支持任意Qt版本、任意系统、任意编译器。

4 省市轮廓下载类功能特点

  1. 定时器排队下载省市轮廓图点坐标集合存储到JS文件。

  2. 支持一个行政区域多个不规则区域下载。

  3. 自动计算行政区域的下载轮廓数量。

  4. 可精确选择省份、市区、县城,也可直接输入行政区域的名称。

  5. 可以设置下载间隔、随时开始下载和停止下载。

  6. 提供编辑边界功能,可以直接在地图上编辑好不规则区域的点集合,然后获取边界点集合数据,这个可以用来自己绘制区域拿到数据,比如某个乡镇甚至某个小区的行政区域数据,很牛逼。

三、体验地址

体验地址:https://pan.baidu.com/s/15ZKAlptW-rDcNq8zlzdYLg  提取码:uyes 文件名:bin_map.zip

国内站点:https://gitee.com/feiyangqingyun

国际站点:https://github.com/feiyangqingyun

四、效果图

Qt如何实现经纬度坐标纠偏

五、相关代码

//常用转换就4种: GPS转百度、GPS转其他、百度转其他、其他转百度//WGS-84: 国际标准,GPS坐标(Google Earth使用、或者GPS模块)//GCJ-02: 中国坐标偏移标准,Google Map、高德、腾讯使用//BD-09:  百度坐标偏移标准,Baidu Map使用static QPointF gcj2bd(const QPointF &point);static QPointF bd2gcj(const QPointF &point);static double transformLng(double lng, double lat);static double transformLat(double lng, double lat);static QPointF wgs2gcj(const QPointF &point);static QPointF wgs2bd(const QPointF &point);//圆周率转换量double x_pi = M_PI * 3000.0 / 180.0;QPointF MapHelper::gcj2bd(const QPointF &point){    double x = point.x();    double y = point.y();    double z = qSqrt(x * x + y * y) + 0.00002 * qSin(y * x_pi);    double theta = qAtan2(y, x) + 0.000003 * qCos(x * x_pi);    double lng = z * qCos(theta) + 0.0065;    double lat = z * qSin(theta) + 0.006;    return QPointF(lng, lat);}QPointF MapHelper::bd2gcj(const QPointF &point){    double x = point.x() - 0.0065;    double y = point.y() - 0.006;    double z = qSqrt(x * x + y * y) - 0.00002 * qSin(y * x_pi);    double theta = qAtan2(y, x) - 0.000003 * qCos(x * x_pi);    double lng = z * qCos(theta);    double lat = z * qSin(theta);    return QPointF(lng, lat);}double MapHelper::transformLng(double lng, double lat){    double ret = 300.0 + lat + 2.0 * lng + 0.1 * lat * lat + 0.1 * lat * lng + 0.1 * qSqrt(qAbs(lat));    ret += (20.0 * qSin(6.0 * lat * M_PI) + 20.0 * qSin(2.0 * lat * M_PI)) * 2.0 / 3.0;    ret += (20.0 * qSin(lat * M_PI) + 40.0 * qSin(lat / 3.0 * M_PI)) * 2.0 / 3.0;    ret += (150.0 * qSin(lat / 12.0 * M_PI) + 300.0 * qSin(lat / 30.0 * M_PI)) * 2.0 / 3.0;    return ret;}double MapHelper::transformLat(double lng, double lat){    double ret = -100.0 + 2.0 * lat + 3.0 * lng + 0.2 * lng * lng + 0.1 * lat * lng + 0.2 * qSqrt(qAbs(lat));    ret += (20.0 * qSin(6.0 * lat * M_PI) + 20.0 * qSin(2.0 * lat * M_PI)) * 2.0 / 3.0;    ret += (20.0 * qSin(lng * M_PI) + 40.0 * qSin(lng / 3.0 * M_PI)) * 2.0 / 3.0;    ret += (160.0 * qSin(lng / 12.0 * M_PI) + 320 * qSin(lng * M_PI / 30.0)) * 2.0 / 3.0;    return ret;}//卫星椭球坐标投影到平面地图坐标系的投影因子double a = 6378245.0;//椭球的偏心率double ee = 0.00669342162296594323;QPointF MapHelper::wgs2gcj(const QPointF &point){    double x = point.x();    double y = point.y();    double lng = transformLng(y - 35.0, x - 105.0);    double lat = transformLat(y - 35.0, x - 105.0);    double rad = y / 180.0 * M_PI;    double magic = qSin(rad);    magic = 1 - ee * magic * magic;    double sqrtMagic = qSqrt(magic);    lng = x + (lng * 180.0) / (a / sqrtMagic * qCos(rad) * M_PI);    lat = y + (lat * 180.0) / ((a * (1 - ee)) / (magic * sqrtMagic) * M_PI);    return QPointF(lng, lat);}QPointF MapHelper::wgs2bd(const QPointF &point){    //GPS转百度要经过两重转换    return gcj2bd(wgs2gcj(point));}

到此,相信大家对“Qt如何实现经纬度坐标纠偏”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Qt如何实现经纬度坐标纠偏

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Qt如何实现经纬度坐标纠偏

本篇内容主要讲解“Qt如何实现经纬度坐标纠偏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Qt如何实现经纬度坐标纠偏”吧!一、前言地图应用中都涉及到一个问题就是坐标纠偏的问题,这个问题的是因为根
2023-06-29

Qt+GDAL库实现制作经纬度坐标转换工具

这篇文章主要为大家详细介绍了如何利用Qt和GDAL库实现制作经纬度坐标转换工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下
2023-05-16

怎么使用Qt+GDAL库实现制作经纬度坐标转换工具

今天小编给大家分享一下怎么使用Qt+GDAL库实现制作经纬度坐标转换工具的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、功
2023-07-06

python如何实现用经纬度点坐标读取DEM中的高程信息

这篇文章主要为大家展示了“python如何实现用经纬度点坐标读取DEM中的高程信息”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“python如何实现用经纬度点坐标读取DEM中的高程信息”这篇文章
2023-06-29

如何用Python实现地理位置和经纬度坐标之间的转换

如何用Python实现地理位置和经纬度坐标之间的转换 ,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。做地图可视化时需要提供经纬度坐标,但一般来说我们手上拿到的通
2023-06-15

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录