R:从生成的图像中剪下 shapefile 边界

R: Clip a shapefile boundary out of a generated image

我生成了一张普通克里格预测图像。我有一个边界线的 shapefile,我想以该 shapefile 的形状裁剪普通的克里格预测。

这是我用来生成图像的代码: 图像(OK.pred,loc=网格,axes=F,useRaster=TRUE)。我只想从图像中剪下一个对象——当我绘制它们时,它们完美地叠加在一起。

它几乎与这里的问题相同,https://gis.stackexchange.com/questions/167170/is-it-possible-to-clip-a-shapefile-to-an-image-in-r,但我对 R 比较陌生,完全迷失了 netcdf 文件部分。

我找到了一堆关于如何裁剪光栅的代码,但我什至不知道如何将图像保存到变量中,更不用说将其转换为光栅以便裁剪了。任何帮助将非常感激!

 OK.pred<-krige.conv(gambling.geo,coords = gambling.geo$coords, data=gambling.geo$data, locations=grid,krige=krige.control(obj.model=gambling.vario.wls))

ordinarykrig = image(OK.pred,loc=grid,axes=F,useRaster=TRUE)

Macau <- readOGR("MAC_adm0.shp")

x <- crop(?...)

摘自http://leg.ufpr.br/geoR/tutorials/kc2sp.R: 您需要先将克里金法输出转换为空间对象,然后才能将其传递给 mask()。以下应该这样做:

OK.pred<-krige.conv(gambling.geo,coords = gambling.geo$coords, data=gambling.geo$data, locations=grid,krige=krige.control(obj.model=gambling.vario.wls))
GT.s <- points2grid(SpatialPoints(as.matrix(grid)))
reorder <- as.vector(matrix(1:nrow(grid), nc=slot(GT.s, "cells.dim")[2])[,slot(GT.s, "cells.dim")[2]:1])
SGDF.s <- SpatialGridDataFrame(grid=GT.s, data=as.data.frame(OK.pred[1:2])[reorder,])
r<-raster(SGDF.s)
x<-mask(r, Macau)