Qt+GDAL库实现制作经纬度坐标转换工具
更新时间:2023年04月17日 08:35:14 作者:欧特克_Glodon
这篇文章主要为大家详细介绍了如何利用Qt和GDAL库实现制作经纬度坐标转换工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下
1、功能界面
下面是用Global Mapper计算的结果,证明计算正确。
2、功能介绍
- 支持CGCS2000/WGS84/XIAN80/BEIJING54四种常用坐标系;
- 自动判断输入经纬度和X/Y坐标的合法性;
- 依据标准3°带自动计算中央子午线;
- 支持经纬度转投影坐标以及投影坐标转经纬度。
3、实现逻辑
1)利用GDAL库构建基础坐标系数据。
OGRSpatialReference m_spatialReference; if(m_Coordinate == CoordinateDialog::CGCS2000) { qDebug() << "CGCS2000"; m_spatialReference.importFromEPSG(4490); } else if(m_Coordinate == CoordinateDialog::WGS84) { qDebug() << "WGS84"; m_spatialReference.importFromEPSG(4326); } else if(m_Coordinate == CoordinateDialog::XIAN80) { qDebug() << "XIAN80"; m_spatialReference.importFromEPSG(4610); } else if(m_Coordinate == CoordinateDialog::BeiJing54) { qDebug() << "BeiJing54"; m_spatialReference.importFromEPSG(4214); }
2)设定投影坐标系并进行转换
m_spatialReference.SetTM(0.0, nMeridian, 1.0, nAreacode*1000000 + nOffsetE, nOffsetN); OGRSpatialReference* pLonLat = m_spatialReference.CloneGeogCS(); // X、Y转经纬度 OGRCoordinateTransformation* pXY2LonLat = OGRCreateCoordinateTransformation(&m_spatialReference, pLonLat); // 经纬度转X、Y OGRCoordinateTransformation* pXY2LonLat = OGRCreateCoordinateTransformation(&m_spatialReference, pLonLat); pXY2LonLat->Transform(1, &dLon, &dLat)
到此这篇关于Qt+GDAL库实现制作经纬度坐标转换工具的文章就介绍到这了,更多相关Qt GDAL经纬度坐标转换内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
C/C++ Qt TreeWidget 单层树形组件应用小结
TreeWidget 目录树组件,该组件适用于创建和管理目录树结构,在开发中我们经常会把它当作一个升级版的ListView组件使用,本文将通过TreeWidget实现多字段显示,并增加一个自定义菜单,通过在指定记录上右键可弹出该菜单并对指定记录进行操作2021-11-11OpenMP Parallel Construct的实现原理详解
在本篇文章当中我们将主要分析 OpenMP 当中的 parallel construct 具体时如何实现的,以及这个 construct 调用了哪些运行时库函数,并且详细分析这期间的参数传递,需要的可以参考一下2023-01-01
最新评论