在栅格上绘制 ggmap 图像

plot ggmap image over raster

我正在尝试从栅格前的 ggmap 绘制地图。这张地图有很多白色区域,所以我想让白色区域透明,这样我就可以使用 ggplot 在彩色栅格上绘制剩余元素。这是地图:

Fulanus_bbox <- c(left = 17.250000, bottom = -3.916667, right = 36.916667, top = 8.416667)
Fulanus_big <- ggmap::get_map(location = Fulanus_bbox, source = "stamen", maptype = "toner-lite")
map <- ggmap::ggmap(Fulanus_big)
map

我能想到的就是这两个解决方案,我没想到它们会起作用,但它们也没有。我试过替换地图上的十六进制代码:

map_colors <- map$layers[[2]]$geom_params$raster
map_colors[map_colors == '#FFFFFF'] <- '#00FFFFFF'
map$layers[[2]]$geom_params$raster <- map_colors
map

我也尝试过将颜色转换为光栅以查看是否保持了图案:

maprow <- nrow(map_colors)
mapcol <- ncol(map_colors)
map_factors <- as.factor(map_colors)
map_numeric <- as.numeric(map_factors)
map_matrix <- matrix(map_numeric, nrow = maprow, ncol = mapcol)
map_raster <- raster::raster(map_matrix)
map_raster <- raster::setExtent(map_raster, Fulanus_bbox)
raster::crs(map_raster) <- "+proj=longlat +datum=WGS84 +no_defs +ellps=WGS84 +towgs84=0,0,0 "
raster::plot(map_raster)

可以吗?如果是,如何?

This map has a lot of white area, so I wanted to make the white area transparent [...]

这似乎有效:

map <- ggmap::ggmap(Fulanus_big)
r <- map$layers[[2]]$geom_params$raster
r[r=="#FFFFFF"] <- NA
map$layers[[2]]$geom_params$raster <- r
map