パッケージsp
は、さまざまな空間概念(点、線、ポリゴン)に対応するいくつかのクラスを提供します。一部のクラスでは、フィーチャ座標にアクセスすることは簡単です。 。すべての例はそれぞれのクラスヘルプページから取られました。 SpatialPolygons
についてSpatialPolygonsおよびその他のspクラスからフィーチャ座標を抽出
l1 = cbind(c(1,2,3),c(3,2,2))
l1a = cbind(l1[,1]+.05,l1[,2]+.05)
l2 = cbind(c(1,2,3),c(1,1.5,1))
Sl1 = Line(l1)
Sl1a = Line(l1a)
Sl2 = Line(l2)
S1 = Lines(list(Sl1, Sl1a), ID="a")
S2 = Lines(list(Sl2), ID="b")
Sl = SpatialLines(list(S1,S2))
coordinates(Sl)
# [prints a list of two with corresponding segments]
、coordinates()
以下に示すように、ポリゴン中心を返します。
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)
coordinates(SpP)
[,1] [,2]
[1,] 2.696970 3.545455
[2,] 3.666667 2.333333
[3,] 6.133333 3.933333
機能座標を抽出する共通のパッケージには便利な機能がありますか?私はSpatialPolygons
の関数を考え出しましたが、よりよくテストされ、一貫性があり、おそらくほとんど/すべてのsp
クラスでさえも、何かを探しています。
getEdges <- function(x) {
stopifnot(class(x) == "SpatialPolygons")
lapply([email protected], function(y) {
[email protected][[1]]@coords
})
}
getEdges(SpP)
# [returns a list of three, coordinates in a matrix]
を私はあなたに非常に良い本をお勧めします! " - > http://www.springerlink.com/content/978-0-387-78171-6#section=147788&page=1 – Pop
一般に、物を取り出すには '@ property'を使うのはお勧めできません。これはオブジェクトの内部組織であり、予告なしに変更される可能性があります。 –