在 shapefile 后面绘制栅格

2024-02-12

如何在 shapefile 对象后面绘制“光栅”对象?两者都可以单独绘制,但这些点不会在栅格上绘制:

require(rgdal)
require(maptools)
require(raster)

myproj = "+proj=utm +zone=12 +north +ellps=WGS84 +units=m"
shp = readShapeSpatial(fn.shp, proj4string = CRS(myproj))
ras = raster(fn.tif)

plot(ras)
plot(shp, bg="transparent", add=TRUE)

使用点、线和多边形重叠绘制栅格图应该可以正常工作,如以下示例所示。

我最好的猜测是Spatial*您尝试在栅格顶部绘制的对象落在正在绘制的区域之外。您是否检查过raster and Spatial*对象位于同一个 CRS 中,并且(假设它们是)边界框重叠? (即尝试bbox(shp) and bbox(ras),并比较结果)。

library(rgdal)
library(raster)
# Create a raster
ras <- raster(ncols=36, nrows=18)
ras[] <- runif(ncell(ras))
# Create a SpatialPoints object
shpPts <- spsample(Spatial(bbox=bbox(ras)), 20, type="random")
# Create a SpatialPolygons object
p1 <- rbind(c(-10,0), c(140,60), c(160,0), c(140,-55), c(-10,0))
shpPolys <- SpatialPolygons( list(Polygons(list(Polygon(p1)), 1)))

# Plot them, one layer after another
plot(ras)
plot(shpPts, pch=16, col="red", add=TRUE)
plot(shpPolys, col="yellow", add=TRUE)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

在 shapefile 后面绘制栅格 的相关文章

随机推荐