library(sp)
library(spdep)
library(ggplot2)
library(ggmap)
library(rgdal)
Получите и возитесь с данными:
nc.sids <- readShapePoly(system.file("etc/shapes/sids.shp", package="spdep")[1],ID="FIPSNO", proj4string=CRS("+proj=longlat +ellps=clrk66"))
nc.sids=spTransform(nc.sids,CRS("+init=epsg:4326"))
Получите фоновую карту с сайта stamen.com, сюжет, красиво смотрится:
ncmap = get_map(location=as.vector(bbox(nc.sids)),source="stamen",maptype="toner",zoom=7)
ggmap(ncmap)
Создайте фрейм данных с длинной, широтой, Z, графиком поверх карты и пустым графиком:
ncP = data.frame(coordinates(nc.sids),runif(nrow(nc.sids)))
colnames(ncP)=c("long","lat","Z")
ggmap(ncmap)+geom_point(aes(x=long,y=lat,col=Z),data=ncP)
ggplot()+geom_point(aes(x=long,y=lat,col=Z),data=ncP)
дайте ему несколько уникальных идентификаторов, называемых id, и укрепите (витаминами и железом?)
nc.sids@data[,1]=1:nrow(nc.sids)
names(nc.sids)[1]="id"
ncFort = fortify(nc.sids)
Теперь, моя карта и мои пределы, я хочу изобразить коэффициент рождаемости 74:
myMap = geom_map(aes(fill=BIR74,map_id=id),map=ncFort,data=nc.sids@data)
Limits = expand_limits(x=ncFort$long,y=ncFort$lat)
а на пустом участке могу:
ggplot() + myMap + Limits
но на ggmap я не могу:
ggmap(ncmap) + myMap + Limits
# Error in eval(expr, envir, enclos) : object 'lon' not found
Некоторые версии:
> packageDescription("ggplot2")$Version
[1] "0.9.0"
> packageDescription("ggmap")$Version
[1] "2.0"
Я могу добавить geom_polygon в ggplot или ggmap, и он работает, как ожидалось. Так что с geom_map что-то не так ....