开发者

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

目录
  • 1、功能界面
  • 2、功能介绍
  • 3、实现逻辑

1、功能界面

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

下面是用Global Mapper计算的结果,证明计算正确。

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

2、功能介绍

  • 支持CGCS2000/WGS84/XIAN80/BEIJING54四种常用坐标系;
  • 自动判断输入经纬度和X/Y坐标的合法性;
  • 依据标准3°带自动计算中央子午线;
  • 支持经纬度转投影坐标以及投影坐标转经纬度。

3、实现逻辑

1)利用GDAL库构建基础坐标系数据。

OGRSpatialReference m_spatialReference;

if(m_Coordinate == CoordinateDialog::CGCS2000)
    {
        qTmCNvWDebug() << "CGCS2000";
        m_spatialReference.importFromEPSG(4490);
    }
    else if(m_Coordinate == CoordinateDialog::WGS84)
    {
        qDebug() << "WGS84";
        m_spatialReference.impo开发者_Python教程rtFromEPSG(4326);
    }
    else if(m_Coordinate == CoordinateDialog::XIAN80)
    {
        qDebug() << "XIAN80";
        m_spatialReference.importFromEPSG(4610);
    }
    else androidif(m_Coordinate == CoordinateDialog::BeiJing54)
    {
        qDebug() << "BeiJing54";
        m_spatialReference.importFromEPSG(4214);
    javascript}

2)设定投影坐标系并进行转换

    m_spatialReference.SetTM(0.0, nMeridian, 1.0, nAreacode*1000000 + nOffsetE, nOffsetN);
	OGRSpatialReferencphpe* pLonLat = m_spatialReference.CloneGeogCS();
	
	// X、Y转经纬度
	OGRCoordinateTransformation* pXY2LonLat = OGRCreateCoordinateTransformation(&m_spatialR编程客栈eference, pLonLat);
	// 经纬度转X、Y
	OGRCoordinateTransformation* pXY2LonLat = OGRCreateCoordinateTransformation(&m_spatialReference, pLonLat);
	
    pXY2LonLat->Transform(1, &dLon, &dLat)

到此这篇关于Qt+GDAL库实现制作经纬度坐标转换工具的文章就介绍到这了,更多相关Qt GDAL经纬度坐标转换内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

0

上一篇:

下一篇:

精彩评论

暂无评论...
验证码 换一张
取 消

最新开发

开发排行榜