15

我希望能够创建一个覆盖另一个 SpatialPolygon 的 SpatialPolygons 对象(它是一个六边形网格)。

我希望所有六边形的直径为 1 公里(理想情况下我可以改变它)并且所有六边形一起覆盖整个物体。下面的方法似乎只涵盖了其中的一小部分......

sp以下是我使用该软件包的尝试:

require(sp)
data(meuse.riv)
meuse.sr = SpatialPolygons(list(Polygons(list(Polygon(meuse.riv)), "x")))
plot(meuse.sr)

HexPts <-spsample(meuse.sr,type="hexagonal",cellsize=1000)
HexPols <- HexPoints2SpatialPolygons(HexPts)
plot(HexPols, add=TRUE)

非常感谢任何帮助...

4

1 回答 1

19

替换meuse.sr为一些缓冲版本,例如rgeos::gBuffer(meuse.sr, width = 2000)调用spsample. 这是一个仅选择相交六边形的完整示例:

require(sp)
data(meuse.riv)
meuse.sr = SpatialPolygons(list(Polygons(list(Polygon(meuse.riv)), "x")))
plot(meuse.sr)

library(rgeos)
meuse.large = gBuffer(meuse.sr, width = 2000)
HexPts <-spsample(meuse.large, type="hexagonal", cellsize=1000)
HexPols <- HexPoints2SpatialPolygons(HexPts)
plot(HexPols[meuse.sr,], add=TRUE)

在此处输入图像描述

于 2015-03-31T17:29:06.493 回答