0

我正在尝试使用 maptools 包中的 wrld_simpl 来绘制一张带有经度/纬度网格的世界地图。

例如,我有一个包含经度和纬度的 netCDF 文件,我创建了一个包含网格上所有点的矩阵:

lat <- get.var.ncdf(nc,"lat")
long <- get.var.ncdf(nc,"lon")
pts <- SpatialPoints(expand.grid(long,lat), CRS(proj4string(wrld_simpl)))

现在我想绘制坐标在我的网格上的国家。

我不知道如何处理 wrld_simpl 属性!

4

1 回答 1

0

你看过maps mapproject包裹吗?您可以使用所需的分辨率非常快速地绘制任何海岸线,并且它带有投影和网格。您可以将投影应用于您的对象之一 ( expand.grid(long,lat))。南极洲的例子:

library("mapproj")
m <- map( "world", "Antarctica", plot=FALSE)
map("world", "Antarctica", proj="conic", param=-90, fill=TRUE, col="gray")
map.grid(m, nx=4, ny=6, col="black")

front.lim <- data.frame(x=seq(-180, 180, length.out=1000),
                        y=rep(-62, 1000))
front.lim <- mapproject(front.lim$x, front.lim$y, projection="conic", parameters=-90)
lines(front.lim$x, front.lim$y, col="red", lwd=2)

如果您已经绘制了 ncdf 矩阵,您可以简单地添加map(add=TRUE). 它将读取 x 和 y 限制并在该区域中绘制边界。

plot(c(-10, 45), c(30, 60), type="n", xlab="", ylab="") # image(ncdf)
map(add=TRUE, fill=TRUE, col="gray")
abline(v=seq(-10, 45, 7.5), lty=2)
abline(h=seq(-30, 60, 7.5), lty=2)
于 2013-11-18T20:11:06.787 回答