示例数据
library(raster)
dat <- getData('GADM', country='FRA', level=1)
plot(dat)
text(dat, labels=as.character(dat$ID_1), col="darkred", font=2, offset=0.5, adj=c(0,2))
要保存各省的ID,我可以这样做
province.id <- dat$ID_1
但是,我想根据某个方向(即从南到北)安排这些ID
例如,我的province.id
id应该从10开始(因为它是最南端的省份)直到17,因为它是最北部省份
我想到的一种方法是我可以根据质心生成每个省的中心,
我可以确定哪个是最南部到最北部的位置。
library(rgeos)
trueCentroids = gCentroid(dat,byid=TRUE)
plot(dat)
points(coordinates(dat),pch=1)
但我仍然无法输出输出或在南北方向排列质心 保存为矢量
答案 0 :(得分:1)
一种简单的方法是获取每个多边形的最小纬度,并根据以下内容对您的ID进行排序:
# data
library(raster)
dat <- getData('GADM', country='FRA', level=1)
# create south to north index
sn_index <- unlist(lapply(dat@polygons, function(x) min(x@Polygons[[1]]@coords[,2])))
#sort IDs
dat$ID_1[order(sn_index)]
# [1] 10 13 21 16 22 3 2 14 20 6 18 8 11 7 1 9 15 4 5 19 12 17