gpt4 book ai didi

r - 如何使用 r 循环在传单 map 中添加多个多边形?

转载 作者:行者123 更新时间:2023-12-02 15:10:27 25 4
gpt4 key购买 nike

我正在尝试根据多个国家/地区代码列表向传单世界地图添加多个多边形。我试图使用 R 循环来添加多边形。这是我从列表 1 中手动添加多边形的代码:

library(sp)
library(raster)
library(leaflet)
library(maps)
library(tidyverse)

countries_1 <- c('PAK','TUR','BGR')

adm1 <- getData('GADM', country='PAK', level=0)
adm2 <- getData('GADM', country= 'TUR', level=0)
adm3 <- getData('GADM', country= 'BGR', level=0)


leaflet() %>%
addTiles() %>%
addPolygons(data=adm1, weight = 3, fillColor = 'purple', color = 'purple') %>%
addPolygons(data=adm2, weight = 3, fillColor = 'purple', color = 'purple') %>%
addPolygons(data=adm3, weight = 3, fillColor = 'purple', color = 'purple')

我正在考虑使用循环添加多个多边形图层,以便 list_n:

 countries_n <- ('ctry1','ctry2','ctry3',...'ctryn') 

for (i in country_n) {

countries <- basemap %>% addPolygons(data=getData('GADM',country = i, level = 0),
weight = 3, fillColor = 'purple', color = 'purple')

}

问题是如何将循环嵌入“leflet() %>%”?

*这里注意:如果尝试在 addPolygons() 中添加多个数据,它将仅绘制数据中的第一个元素,在下面的情况下,将仅绘制国家“PAK”:

addPolygons(data=c('PAK','TUR'), weight = 3, fillColor = 'purple', color = 'purple')

最佳答案

这是一个使用包 sfma​​pview 的解决方案。请注意,这目前只能使用 ma​​pview 的开发版本(请参阅注释掉的 devtools::install_github()

# devtools::install_github("r-spatial/mapview@develop")
library(sf)
library(mapview)
library(raster)

countries_1 <- c('PAK','TUR','BGR')

dat_list = lapply(countries_1, function(i) {
st_as_sf(getData("GADM", country = i, level = 0))
})

m = leaflet() %>% addTiles()

for (i in dat_list) {
m = mapview::addFeatures(map = m,
data = i,
weight = 3,
fillColor = 'purple',
color = 'purple')
}

m

请注意,addFeatures 与类型无关,因此点、线和/或多边形的任意组合都可以在这里工作。

关于r - 如何使用 r 循环在传单 map 中添加多个多边形?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44396743/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com