如何将印度国家与地区划分为r?

时间:2015-06-08 10:18:53

标签: r maps

我想用R软件中的各个地区绘制印度的不同州。我尝试过使用GADM,2级数据来获取坐标。

我已经关注了这个帖子Mapping just one State of India and writing its name inside the state boundary。但是,我无法对任何状态的数据进行子集化,并将其用于映射。

我尝试了什么:

map <- fortify(Karnataka)
map$id <- as.integer(map$id) 
dat <- data.frame(id = 216:242, district = Karnataka) 
map_df <- inner_join(map, dat, by = "id") 
centers <- data.frame(gCentroid(Karnataka, byid = TRUE)) 
centers$state <- dat$district

2 个答案:

答案 0 :(得分:1)

我可以使用以下命令映射状态及其区域边界。

India <- getData("GADM", country = "India", level = 2)  
Karnataka <- subset(India, NAME_1 == "Karnataka")
map <- fortify(Karnataka);  
map$id <- as.integer(map$id);  
dat <- data.frame(id = 216:242, district = Karnataka@data$NAME_2);  
map_df <- inner_join(map, dat, by = "id");  
centers <- data.frame(gCentroid(Karnataka, byid = TRUE));  
centers$state <- dat$district;  


ggplot() +
geom_map(data = map_df, map = map_df,
     aes(map_id = id, x = long, y = lat, group = group),
     color = "#ffffff", fill = "#bbbbbb", size = 0.25) +
geom_text(data = centers, aes(label = state, x = x, y = y), size = 2) +
coord_map() + labs(x = "", y = "", title = "Districts of Karnataka") 

答案 1 :(得分:1)

您可以使用R中的Google地图轻松,轻松地执行此操作。ggmap内有很多选项。以下示例非常基本,但可以通过设置您喜欢的选项来完全自定义。

map <- qmap('Karnataka', zoom = 7, maptype = 'hybrid')
map

enter image description here

library(ggmap)
qmap('Karnataka')

enter image description here