QGIS二次开发:数值表示的墨卡托坐标和经纬度表示的WSG84坐标相互转化

本博文用到的QGIS 版本说明:

QGIS 3.26.2。

经常在QGIS中看到类似如下很大数值表示的坐标,如:

auto mapCenterPt = QgsPointXY(11472426, 4197692);

而大多数情况下,我们对经纬度表示的坐标比较直观和熟悉,如:

103.05855621730184, 35.248420842233159

前者是基于墨卡托坐标下的坐标表示,后者是基于WSG84坐标系下的坐标表示。如下代码可以将墨卡托坐标下的坐标转为WSG84坐标系下的坐标:

/* 功能:将墨卡托坐标系下的点坐标转为WGS84坐标系下的坐标
   curPoint:墨卡托坐标下的点。输入值
   newPoint:WGS84坐标下的点。输出值
*/
void CMyGIS::convertMercatorToWGS84(const QgsPoint& curPoint, QgsPoint& newPoint)
{
    QgsCoordinateReferenceSystem srcCrs("EPSG:3857"); // 墨卡托坐标
	QgsCoordinateReferenceSystem dstCrs("EPSG:4326"); // WSG84坐标
	const QgsCoordinateTransformContext context;
	QgsCoordinateTransform crsTras(srcCrs, dstCrs, context);

	auto tmpPt = crsTras.transform(curPoint);
	newPoint.setX(tmpPt.x());
	newPoint.setY(tmpPt.y());
}

如下代码可以将WSG84坐标下的坐标转为墨卡托坐标系下的坐标:

/* 功能:将WGS84坐标系下的点坐标转为墨卡托坐标系下的坐标
   curPoint:WGS84坐标下的点。输入值
   newPoint:墨卡托坐标下的点。输出值
*/
void CMyGIS::convertWGS84ToMercator(const QgsPoint& curPoint, QgsPoint& newPoint)
{
	QgsCoordinateReferenceSystem srcCrs("EPSG:4326"); // WSG84坐标
	QgsCoordinateReferenceSystem dstCrs("EPSG:3857"); // 墨卡托坐标
	const QgsCoordinateTransformContext context;
	QgsCoordinateTransform crsTras(srcCrs, dstCrs, context);

	auto tmpPt = crsTras.transform(curPoint);
	newPoint.setX(tmpPt.x());
	newPoint.setY(tmpPt.y());
}

说明:上述代码用到的QGIS版本为QGIS 3.26.2。

关于墨卡托坐标系和WSG84坐标系之间的理论原理讲解,请参见:墨卡托坐标以及墨卡托坐标转经纬度_荆楚闲人的博客-CSDN博客

QGIS二次开发中,您可以使用以下代码将画布(MapCanvas)的坐标系设置为国家2000坐标系(EPSG:4547): ```cpp #include <qgsproject.h> #include <qgscoordinateutils.h> // 设置画布坐标系为国家2000坐标系 void setCanvasCrsToNational2000() { QgsProject *project = QgsProject::instance(); // 获取国家2000坐标系(EPSG:4547)的坐标参考系统对象 QgsCoordinateReferenceSystem national2000Crs("EPSG:4547"); // 将国家2000坐标系设置为项目的默认坐标参考系统 project->setCrs(national2000Crs); // 获取当前地图窗口的画布对象 QgsMapCanvas *canvas = project->mapCanvas(); // 设置画布的坐标参考系统为国家2000坐标系 canvas->setDestinationCrs(national2000Crs); } int main() { // 初始化QGIS项目 QgsApplication app(argc, argv); QgsApplication::initQgis(); // 设置画布坐标系为国家2000坐标系 setCanvasCrsToNational2000(); // 执行其他的二次开发操作 // 释放QGIS资源 QgsApplication::exitQgis(); return 0; } ``` 上述示例代码中,首先通过`QgsProject::instance()`获取项目实例,并使用`setCrs()`方法将项目的默认坐标参考系统设置为国家2000坐标系。然后通过`QgsMapCanvas`获取画布对象,并使用`setDestinationCrs()`方法将画布的坐标参考系统设置为国家2000坐标系。 请注意,这只是一个简单的示例,您可能需要根据您的实际需求进行适当的修改和扩展。另外,确保在使用QGIS API之前正确初始化和关闭QGIS应用程序(如示例代码中的`QgsApplication::initQgis()`和`QgsApplication::exitQgis()`)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值