有人知道如何在R中计算2个或多个多边形之间的共同区域吗?我希望这样的计算输出是该重叠区域的新多边形的坐标。
谢谢
有人知道如何在R中计算2个或多个多边形之间的共同区域吗?我希望这样的计算输出是该重叠区域的新多边形的坐标。
谢谢
编辑:现在我会使用“raster”包中的“intersect”,“cover”,“erase”,“union”和相关函数。它们可以完成保留顶级对象和属性的繁重工作。
原始内容:
您可以使用rgeos
包及其gIntersection
函数。通过对成对图形进行连续调用并获取结果交集,最终可以达到目的。请参见
library(rgeos)
?gIntersection
要获取最终坐标,您需要深入了解sp
包中的"SpatialPolygons"结构。请参阅vignette("sp")。
我想补充一下我最终使用的解决方案 - 来自 PBSmapping
包的 joinPolys
函数。
library(PBSmapping)
p1 <- data.frame(PID=rep(1, 4), POS=1:4, X=c(1,1,6,6), Y=c(1,3,3,1))
p2 <- data.frame(PID=rep(2, 5), POS=1:5, X=c(4,4,8,8,6), Y=c(2,4,4,2,1))
p3 <- joinPolys(p1,p2)
x11()
par(mar=c(3,3,1,1))
plot(1,1,ylim=c(0,5),xlim=c(0,9), t="n", xlab="", ylab="")
polygon(p1$X, p1$Y, border=2)
polygon(p2$X, p2$Y)
polygon(p3$X, p3$Y, col=rgb(0,0,1,0.2))