栅格数据投影转换
作者:阿振
邮箱:tanzhenyugis@163.com
博客:https://blog.csdn.net/theonegis/article/details/80089375
修改时间:2018-06-01
声明:本文为博主原创文章,转载请注明原文出处
使用GDAL提供的命令行工具进行转换
GDAL提供了gdalwarp
命令可以方便地让我们进行影像拼接,重投影,裁剪,格式转换等功能
比如,我们需要将MODIS数据的Sinusoidal投影转为UTM投影,我们可以这样操作。
我需要转换的地区位于UTM的49度带内,我查看了一下其EPSG的编码为:EPSG:32649(WGS 84 / UTM zone 49N)
注:推荐大家一个网站,可以查阅各种投影的定义:http://spatialreference.org
然后,终端中执行如下命令:
gdalinfo MOD09A1.A2017361.h28v06.006.2018005034659.hdf
(用于查看MODIS数据中的波段名称与地址,这里我们只转换第一波段)
gdalwarp -t_srs EPSG:32649 HDF4_EOS:EOS_GRID:"MOD09A1.A2017361.h28v06.006.2018005034659.hdf":MOD_Grid_500m_Surface_Reflectance:sur_refl_b01 MODSI_WARP_32649.tif
(-t_srs
参数用于指定输出投影信息,可以是EPSG,或者OGC WKT,或者PROJ4格式,后面分别是输入数据和输出数据文件名)
使用代码进行转换
使用命令行转换,当然有两种方法啦:
第一,直接在代码中调用命令行工具的接口(比较懒的人,像我,当然直接用第一种啦,有现成的工具为什么不用);
第二,自己做投影转换之后的坐标计算,主要是计算重投影之后的GeoTransform参数,有了GeoTransform参数以及投影的定义,我们就可以通过SetGeoTransform()
和SetProjection()
投影转换了.
下面我给出具体的实现代码:
第一种方法直接调用gdal.Warp()
方法,该方法其实就是对gdalwarp
命令的封装,第一个参数是输出文件,第二个参数是输入文件或者输入的Dataset,后面的都是可选参数(dstSRS参数指定输出投影)
在介绍第二种方法之前,我们有必要回忆一下之前说过的GDAL反射变换的六参数模型:
放射变换使用如下的公式表示栅格图上坐标和地理坐标的关系:
($X{ge0}$, $Y{ge0}$)表示对应于图上坐标($X{pixel}$, $Y{line}$)的实际地理坐标。对一个上北下南的图像,GT(2)和GT(4)等于0, GT(1)是像元的宽度, GT(5)是像元的高度的相反数。(GT(0),GT(3))坐标对表示左上角像元的左上角坐标。
通过这个放射变换,我们可以得到图上所有像元对应的地理坐标。
好了,所以我们需要计算对于上面的六参数,我们主要需要计算重投影以后图像左上角的坐标(最小的X坐标值和最大的Y坐标值),这个转换我们可以通过osr.CoordinateTransformation
类进行,下面给出实现代码:
Last updated