使用 R 中的 lat 和 lng 坐标将颜色段添加到地图上的位置

Posted

技术标签:

【中文标题】使用 R 中的 lat 和 lng 坐标将颜色段添加到地图上的位置【英文标题】:Add color segments to location on a map plot by using lat and lng coordinates in R 【发布时间】:2022-01-04 05:34:40 【问题描述】:

我的数据集有 4 列,分别是 station_namestation_latstation_lngcount。这是我的数据集的示例。

start_stations <-
  data.frame(
    station = c("StreeterDr", "MichiganAve", "WellsSt"),
    lat = c(41.89228, 41.90096, 41.91213),
    lng = c(-87.61204,-87.62378,-87.63466),
    n = c(23000, 56780, 34520)
  )

我需要根据站点(位置)的计数使用这些坐标和颜色变化绘制地图,并使用名称和计数标记每个位置。我试了这段代码,出现了错误。

install.packages(c("leaflet", "sp")) 
library(leaflet)
library(sp)
install.packages("sf")
library(sf)

lon <- start_stations$lng
lat <- start_stations$lat
name <- start_stations$station
count <- start_stations$n
dfs <- as.data.frame(cbind(lon,lat,name,count))

dfs<- st_as_sf(dfs)

getColor <- function(dfs) 
  sapply(dfs$count, function(count) 
  if(count <= 20000) 
    "green"
   else if(count <= 30000) 
    "orange"
   else 
    "red"
   )


icons <- awesomeIcons(
  icon = 'ios-close',
  iconColor = 'black',
  library = 'ion',
  markerColor = getColor(top100_start_station_cordinates)
)

leaflet(dfs) %>% addTiles() %>%
  addAwesomeMarkers(~lon, ~lat, icon=icons, popup = ~as.character(name), label=~as.character(count))

【问题讨论】:

错误的确切措辞是什么?它发生在哪里? 这是错误:“st_sf(x, ..., agr = agr, sf_column_name = sf_column_name) 中的错误:不存在简单的特征几何列” 【参考方案1】:

使用st_as_sf时需要定义coords

dfs <- sf::st_as_sf(dfs, coords = c("lon","lat"))

# But you might also want to go ahead and define the projection here too. 
# If so, then add in the crs argument.
# dfs <- sf::st_as_sf(dfs, coords = c("lon", "lat"), crs = 4326)

输出

Simple feature collection with 3 features and 2 fields
Geometry type: POINT
Dimension:     XY
Bounding box:  xmin: -87.63466 ymin: 41.89228 xmax: -87.61204 ymax: 41.91213
CRS:           NA
         name count                   geometry
1  StreeterDr 23000 POINT (-87.61204 41.89228)
2 MichiganAve 56780 POINT (-87.62378 41.90096)
3     WellsSt 34520 POINT (-87.63466 41.91213)

然后,您应该能够运行剩余的代码并获得传单输出。

【讨论】:

电源线正常工作。显示站名和计数,但未显示位置图标。

以上是关于使用 R 中的 lat 和 lng 坐标将颜色段添加到地图上的位置的主要内容,如果未能解决你的问题,请参考以下文章

如何将 Google Maps plus 代码转换为 Lng 和 Lat 坐标

将webmercator坐标转换为lat lng

将地理坐标从 GEOSTAT 转换为 lat 和 lng

如果我有一个 lat/lng,我假设它是 0,0,那么我如何计算另一个 lat/lng 对的 x、y 坐标?

防止 geocomplete 从 lat lng 坐标返回街道地址

在两个位置之间的直线上的各个位置推导出 Lat\Lng 坐标