正如标题所示,我试图使用RgoogleMaps中的PlotPolysonStaticMap函数绘制多边形。我的多边形是来自世界自然基金会(WWF)生态区域的更大数据集的子集。由于我的生态区域的界限限制了另一个生态区域的界限,所以应该有一个洞#34;或在我的多边形中间的空白区域。当我使用绘图功能绘制shapefile时,孔显示为白色。当我从RgoogleMaps在基本地图上绘制多边形时,洞会以彩色显示,我不知道如何更改它。
完整地图可用here。它需要下载并解压缩才能使我的代码正常工作。
library(rgdal)
library(RgoogleMaps)
library(PBSmapping)
WWF<-readOGR(dsn="wwf_terr_eco.shp",layer="wwf_terr_eco"
ACADIA<-WWF[WWF@data$ECO_NAME%in%c("New England-Acadian forests"),]
ACADIA <- SpatialPolygons(ACADIA@polygons,proj4string=ACADIA@proj4string)
add.alpha <- function(col, alpha=1){
if(missing(col))
stop("Please provide a vector of colours.")
apply(sapply(col, col2rgb)/255, 2,
function(x)
rgb(x[1], x[2], x[3], alpha=alpha))
}
mycol=add.alpha("#507415",alpha=.4)
terrMap<-GetMap(center=c(46,-66.8),zoom=6,maptype="terrain")
PlotOnStaticMap(terrMap)
PlotPolysOnStaticMap(terrMap, ACADIA_ONLY,col =mycol ,border = NULL, lwd = 0.25,
verbose = T)
谢谢!
答案 0 :(得分:0)
我不太了解RgoogleMaps
包(错误似乎来自复杂多边形的函数PlotPolysOnStaticMap
行为),因此我无法准确回答您的问题,但是我有一个您可以使用其他方式OpenStreetMap
。
library(rgdal)
library(OpenStreetMap)
WWF<-readOGR(dsn="/home/delaye/Téléchargements/official/",layer="wwf_terr_ecos")
ACADIA<-WWF[WWF@data$ECO_NAME%in%c("New England-Acadian forests"),]
##reprojection with osm system
ACADIA<-spTransform(ACADIA,osm())
##alpha definition
add.alpha <- function(col, alpha=1){
if(missing(col))
stop("Please provide a vector of colours.")
apply(sapply(col, col2rgb)/255, 2,
function(x)
rgb(x[1], x[2], x[3], alpha=alpha))
}
mycol=add.alpha("#507415",alpha=.4)
##load data from osm (you can play with type='bing' to)
map.osm<-openmap(c(49.849184,-75.214844),c(42.013233,-59.877930),type="osm")
plot(map.osm)
##add you datalayer on the plot
plot(ACADIA,add=T,col=mycol)
,结果是
我希望它可以提供帮助