在 R 中,我有一个SpatialPolygons
包含数百个多边形的对象(即多多边形)。我想将此SpatialPolygons
对象拆分为一个列表Polygons
(即孔应保持连接到父多边形)。
知道怎么做吗?
编辑:
使用包中提供的以下示例sp
:
# simple example, from vignette("sp"):
Sr1 = Polygon(cbind(c(2,4,4,1,2),c(2,3,5,4,2)))
Sr2 = Polygon(cbind(c(5,4,2,5),c(2,3,2,2)))
Sr3 = Polygon(cbind(c(4,4,5,10,4),c(5,3,2,5,5)))
Sr4 = Polygon(cbind(c(5,6,6,5,5),c(4,4,3,3,4)), hole = TRUE)
Srs1 = Polygons(list(Sr1), "s1")
Srs2 = Polygons(list(Sr2), "s2")
Srs3 = Polygons(list(Sr3, Sr4), "s3/4")
SpP = SpatialPolygons(list(Srs1,Srs2,Srs3), 1:3)
然后运行out = lapply(SpP@polygons, slot, "Polygons")
。我得到三个列表Polygons
(即Srs1
, Srs2
, Srs3
)。
然而,我试图解决的案例与这个例子有点不同。SpatialPolygons
我要拆分的对象是使用gUnaryUnion
函数(在RGEOS
包中)完成的几何联合的结果。如果我申请out <- lapply(merged.polygons@polygons, slot, "Polygons")
,我会得到一个唯一的Polygon
对象列表(nb 不是Polygons
对象列表)。换句话说,每个多边形都与其孔分开。
跑步 topol <- sapply(unlist(out), function(x) x@hole)
我得到:
> length(topol)
[1] 4996
> sum(topol, na.rm=TRUE)
[1] 469
根据RGEOS
v0.3-2 手册(http://cran.r-project.org/web/packages/rgeos/rgeos.pdf):
为了使 rgeos 正常工作,给定 POLYGON 或 MULTIPOLYGON 几何图形中的所有孔必须属于特定多边形。SpatialPolygons 类实现当前不包含此信息。为了解决这个限制,rgeos 在 Polygons 类上使用了一个额外的注释属性,该属性指示哪个孔属于哪个多边形。在当前实现下,此注释是由空格分隔的数字文本字符串,其中数字的顺序对应于 Polygons 对象的 Polygons 槽中的 Polygon 对象的顺序。0 表示 Polygon 对象是一个多边形,非零数字表示 Polygon 对象是一个孔,其值指示“拥有”该孔的 Polygon 的索引。
所以中的createSPComment()
函数RGEOS
很可能是重新聚合多边形和孔的一种解决方法。