我有关于地理信息的情报。使用gdal,我可以将光栅文件转换为数组(numpy)。
如何获得数组中一个条目的坐标?
发布于 2015-01-13 00:27:02
使用仿射变换矩阵,将像素坐标映射到世界坐标。例如,使用仿射包。(使用简单的数学,还有其他方法可以做到这一点。)
from affine import Affine
fname = '/path/to/raster.tif'这里有两种方法可以得到仿射变换矩阵,T0。例如,使用GDAL/Python:
from osgeo import gdal
ds = gdal.Open(path, gdal.GA_ReadOnly)
T0 = Affine.from_gdal(*ds.GetGeoTransform())
ds = None # close例如,使用雷斯特里欧
import rasterio
with rasterio.open(fname, 'r') as r:
T0 = r.affineGDAL (T0)使用的转换数组的约定是引用像素角。您可能想要引用像素中心,因此它需要翻译50%:
T1 = T0 * Affine.translation(0.5, 0.5)现在,要将像素坐标转换为世界坐标,可以用一个简单的函数将坐标与矩阵相乘:
rc2xy = lambda r, c: T1 * (c, r)现在,获取第一行第二列(索引[0, 1])中光栅的坐标:
print(rc2xy(0, 1))另外,请注意,如果需要从世界坐标中获取像素坐标,则可以使用倒仿射变换矩阵~T0。
https://stackoverflow.com/questions/27861197
复制相似问题