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博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值