R: plotting neighbouring countries using maptools

青春壹個敷衍的年華 提交于 2019-12-20 04:25:10

问题


Say I am plotting countries on a world map using maptools, if I were to plot a country, is there a way of plotting the countries that border this country in a different colour? I am using the shapefile wrld_simpl that comes with maptools, so say I plot China:

plot(wrld_simpl[wrld_simpl$NAME=='China',], col='red', add=T)

is there a way I can get it to plot all the bordering countries to China. I want to be able to do this for lots of different countries so I'd ideally want a general solution, not one specific to just China.


回答1:


How about gTouches or gIntersects in rgeos?

library(rgeos)
library(maptools)
wc <- subset(wrld_simpl, NAME == "China")
world <- subset(wrld_simpl, !NAME == "China")

Create a vector to store the test:

tst <- logical(nrow(world))

Do the test:

for (i in 1:nrow(world)) {
    tst[i] <- gTouches(wc, world[i,])
}

See the result:

levels(world$NAME)[world$NAME[tst]]
[1] "India"  "Russia"

plot(wc)
plot(world[tst, ], add = TRUE, col = "grey")

(No further correspondence on world affairs will be entered into, but gIntersects seems to give a better answer).

I strongly advise you to treat these built-in data sets with caution, you certainly need to get your hands on reliable data if you are to use such a tool for any non-trivial purpose. Geometry and data are tricky enough already. :)

for (i in 1:nrow(world)) {
     tst[i] <- gIntersects(wc, world[i,])
 }
length(levels(world$NAME)[world$NAME[tst]])
[1] 14
 plot(world[tst, ], col = "firebrick")
 plot(wc, add = TRUE, col = "grey")


来源:https://stackoverflow.com/questions/18102330/r-plotting-neighbouring-countries-using-maptools

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!