Построение растра позади шейп-файла

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

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)

person Benjamin    schedule 14.02.2012    source источник


Ответы (1)


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

Мое лучшее предположение состоит в том, что объекты 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)

введите здесь описание изображения

person Josh O'Brien    schedule 14.02.2012
comment
Хороший звонок, мой растр был неправильно расположен. Спасибо за подтверждение, что это работает правильно. - person Benjamin; 15.02.2012