我想基于SpatialPolygons
对象剪裁栅格图像。我知道我们可以使用raster
软件包中的crop
函数。
raster::crop(rasterFile, SpatialPolygonsObject)
但是这个函数基于SpatialPolygons
对象的extent
,因此裁剪结果是一个矩形。然而,在某些情况下,SpatialPolygons
对象不是矩形,如何处理这些情况?
raster::mask
函数。以下是一个可复现的示例:library(raster)
r = raster(vals = rnorm(400), nrows=20, ncols=20, ext= extent(c(0, 20, 0, 20)))
p = Polygon(matrix(5, 5, 15, 12, 7, 16, 3, 10), ncol=2, byrow = T))
p = SpatialPolygons(list(Polygons(list(p), "p")))
plot(r)
lines(p)
r2 = mask(r,p)
plot(r2)
如果您还需要剪切栅格的范围以删除掩膜周围的空行和列,则可以在应用掩膜之前使用crop
,或者之后使用trim(r2,values = NA)
。
mask
操作之前,您可以先进行crop
操作,以尽可能消除更多的细胞。 - Robert Hijmanstrim(r2, values = NA)
。 - Claudia