我在这里绘制地图,无法正确填写,希望您能提供帮助。那我该怎么办
阅读地图并更改投影:
map<-readOGR(dsn="e:\\r\\OSM_adm_reg\\adm4_region (1)", layer="adm4_region")
map=spTransform(map,CRS("+proj=latlong +ellips=GRS80"))
读取全国各地物流仓库位置数据,匹配world.cities数据库在地图上绘制:
data(world.cities)
russian.cities=world.cities[world.cities$country.etc=="Russia",]
metro_outlets=read.csv(file="e:\\r\\retail\\metro.csv",head=TRUE,sep=";")
match<-match(metro_outlets$CITY_ENGLISH, russian.cities$name)
outlet_coordinates=russian.cities[match,]
outlet_coordinates=cbind(outlet_coordinates, "metro_store_count"=metro_outlets$STORE_COUNT_METRO)
outlet_coordinates=cbind(outlet_coordinates, "cch_depo"=metro_outlets$DEPO_FOOD)
outlet_coordinates=cbind(outlet_coordinates, "NAME_LAT"=metro_outlets$STORE_OBLAST)
outlet_coordinates=cbind(outlet_coordinates, "cch_franchise"=metro_outlets$Franchise)
outlet_coordinates=cbind(outlet_coordinates, "SL"=metro_outlets$SL)
基本上,我需要根据 SL 列的值填充区域。现在,我试图获取包含 WH 的区域列表:
outlet_spatial=SpatialPoints(outlet_coordinates[,c(5,4)],proj4string=CRS(proj4string(map)))
index=over(outlet_spatial,map)
region_names=rownames(map@data[map@data$NAME_LAT %in% index$NAME_LAT,])
map_df<-fortify(map,map$NAME_LAT)
map_df$fill=ifelse(map_df$id %in% region_names,"true","false")
并绘制地图:
ggplot()+
geom_polygon(data=map_df,aes(x=long,y=lat,group=group,fill=fill),col="gray")+
scale_fill_manual(values=c("gray","gray70"))+xlim(20, 180) + ylim(40,80)+
geom_point(aes(x=long,y=lat), color="orange",alpha=I(8/10), data=outlet_coordinates)
这是我得到的地图!
现在,我不知道如何将 SL 列的值传递给map_df
并相应地填充区域。SL 在这里定义: outlet_coordinates=cbind(outlet_coordinates,"SL"=metro_outlets$SL)