R - 在循环中按属性缓冲 SpatialPolygons

标签 r for-loop spatial

如何在 SpatialPolygonsDataFrame 中缓冲 SpatialPolygon,每个 SpatialPolygon 具有从其属性获取的特定宽度。

以下示例的代码取自SpatialPolygons - Creating a set of polygons in R from coordinates并稍作修改:

square <- t(replicate(50, {
  o <- runif(2)
  c(o, o + c(0, 0.1), o + 0.1, o + c(0.1, 0), o)
}))
ID <- paste0('sq', seq_len(nrow(square)))

# Create SP
polys <- SpatialPolygons(mapply(function(poly, id) {
  xy <- matrix(poly, ncol=2, byrow=TRUE)
  Polygons(list(Polygon(xy)), ID=id)
}, split(square, row(square)), ID))

# Create SPDF
polys.df <- (polys, data.frame(id=ID, row.names=ID))
polys.df$radius <- runif(50, 2.0, 8)

> head(polys.df)
      radius
sq1 7.397579
sq2 5.123130
sq3 4.607719
sq4 4.052619
sq5 6.571260
sq6 3.912436

每个 SpatialPolygon 应使用其“半径”列的值进行缓冲。

尝试以下循环只会产生一个 SpatialPolygon 作为输出

for (i in length(polys.df)) {
  polys.df.buffer <- gBuffer(polys.df[i,], width=polys.df$radius[i])
}

以下循环返回使用相同缓冲区宽度缓冲的所有多边形,但不使用“半径”列中指定的每个多边形的定义缓冲区宽度:

for (i in length(CrownsOut)) {
  polys.df.buffer <- gBuffer(polys.df[ ], width=polys.df$radius[i], byid=TRUE)
}

最佳答案

代码几乎是正确的。您需要在 for 循环之前初始化一个列表,并在每次迭代中分配缓冲的 Polygon。还需要在循环条件中添加1:length(polys.df),否则只会取最后一个多边形,并且需要为每个多边形分配一个ID .

library(rgeos)

spList = vector("list", length(polys.df))
for (i in 1:length(polys.df)) {
  a <- gBuffer(polys.df[i,], width = polys.df$radius[i])
  a$id = i
  spList[[i]] <- a
}

spListAll <- do.call("rbind", spList)

plot(spListAll)

关于R - 在循环中按属性缓冲 SpatialPolygons,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51303344/

相关文章:

MySql 几何 : How to populate table with a multipolygon from an multi-dimensional array?

r - 如何在 R 中将单个数字与矩阵绑定(bind)

javascript - 两个数组,其中数组 x 中的项目可以在数组 y 中但反之亦然,测试所有排列

arrays - Rust中的意外行为 “for in n..m”

c# - Entity Framework 空间聚合函数

mysql - 如何将形状文件导入MySQL

r - 在 R 中使用 ggplot 为两个不同组创建折线图

r - 追加/合并形状文件

excel - R读取带回车的Excel文件

Java : Serial port enumeration and the for-loop