Построение растра за шейп-файлом - PullRequest
10 голосов
/ 14 февраля 2012

Как я могу построить «растровый» объект за объектом шейп-файла?Оба строятся хорошо самостоятельно, но точки не растягиваются на растре:

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)

1 Ответ

17 голосов
/ 14 февраля 2012

Наложение растровых графиков с точками, линиями и полигонами должно работать нормально, как показано в следующем примере.

Моим лучшим предположением было бы то, что Spatial* объекты, которые вы пытаетесь нанести поверх растра, выпадают за пределы области, в которой они наносятся. Проверяли ли вы, что оба объекта raster и Spatial* находятся в одном и том же CRS и (если они есть), что ограничивающие рамки перекрываются? (то есть попробуйте bbox(shp) и 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)

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...