Raf*_*íaz 2 r openstreetmap r-sf
我正在使用osmdata包来查找哥伦比亚波哥大某个部门的银行。直接使用overpass网页时,找到如下对象,但是R API没有找到。问题是什么?
使用天桥
node[amenity=bank]
(4.6304414673187,-74.075607061386,4.6332058140013,-74.072549343109);
out;
Run Code Online (Sandbox Code Playgroud)
使用 R
library(osmdata)
library(mapview)
my_box <- c(4.6304414673187,-74.075607061386,4.6332058140013,-74.072549343109);
bank_pol <- opq(bbox = my_box, timeout = 25*100) %>%
add_osm_feature(key = "amenity", "bank") %>%
osmdata_sf()
bank_pol$osm_polygons
Simple feature collection with 0 features and 1 field
bbox: xmin: 1.797693e+308 ymin: 1.797693e+308 xmax: -1.797693e+308 ymax: -1.797693e+308
geographic CRS: WGS 84
[1] osm_id geometry
<0 rows> (or 0-length row.names)
mapview(bank_pol$osm_polygons)
Run Code Online (Sandbox Code Playgroud)
该my_box可以是一个matrix或vector作为documenation的opq说
bbox - (i) 以 c(xmin, ymin, xmax, ymax) 形式指定最大和最小经度和纬度的四个数值或 (ii) 以 xmin,ymin,xmax,ymax 形式的字符串。这些将传递给 getbb 以转换为数字边界框。也可以是 (iii) 表示从 getbb(..., format_out = "polygon") 返回的边界多边形的矩阵。
使用getbb,生成的输出是matrix顶行 x 值和下方 y 值的 a
getbb("Bogota", display_name_contains = "Colombia")
# min max
#x -74.223514 -74.01025
#y 4.471175 4.83317
getbb("Bogota", display_name_contains = "Colombia") %>%
opq() %>%
add_osm_feature(key = "amenity", "bank") %>%
osmdata_sf() -> bank_pol
Run Code Online (Sandbox Code Playgroud)
因此,如果我们检查 OP's vector,某些 'x' 和 'y' 值会颠倒。它可以被创建为
my_box <- c(-74.075607061386, 4.6304414673187, -74.072549343109, 4.6332058140013)
Run Code Online (Sandbox Code Playgroud)
现在,调用 opq
bank_pol <- opq(bbox = my_box, timeout = 25*100) %>%
add_osm_feature(key = "amenity", "bank") %>%
osmdata_sf()
Run Code Online (Sandbox Code Playgroud)
- 检查数据
bank_pol$osm_polygons
#Simple feature collection with 3 features and 18 fields
#geometry type: POLYGON
#dimension: XY
#bbox: xmin: -74.07552 ymin: 4.630524 xmax: -74.07264 ymax: 4.633099
#geographic CRS: WGS 84
# osm_id name addr.city addr.country addr.district #addr.housenumber addr.state addr.street
#392010374 392010374 Bancolombia Bogotá CO Teusaquillo 40-95 Distrito Capital Carrera 24
#392010458 392010458 Banco AV Villas Bogotá CO Teusaquillo 40-71/73 <NA> Carrera 24
#394955633 394955633 <NA> Bogotá CO Teusaquillo 42-19 <NA> Carrera 24
# addr.suburb amenity atm brand brand.wikidata brand.wikipedia building building.levels operator
#392010374 La Soledad bank yes Bancolombia Q806206 en:Bancolombia yes 2 Bancolombia
#392010458 La Soledad bank <NA> <NA> <NA> <NA> yes 4 <NA>
#394955633 La Soledad bank yes <NA> <NA> <NA> yes 2 Davivienda
# source geometry
#392010374 Kaart Ground Survey 2017 POLYGON ((-74.07546 4.63140...
#3392010458 Kaart Ground Survey 2017 POLYGON ((-74.07546 4.63112...
#394955633 <NA> POLYGON ((-74.0754 4.632585...
Run Code Online (Sandbox Code Playgroud)
-阴谋
mapview(bank_pol$osm_polygons)
Run Code Online (Sandbox Code Playgroud)
也可以使用 ggmap
library(ggplot2)
library(ggmap)
library(sf)
library(osmdata)
bogota_map <- get_map(getbb("Bogota",
display_name_contains = "Colombia"), maptype = "toner-background")
ggmap(bogota_map) +
geom_sf(data = bank_pol$osm_points, inherit.aes = FALSE,
colour = "#238443",
fill = "#004529",
alpha = .5,
size = 4,
shape = 21)+
labs(x = "", y = "")
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
57 次 |
| 最近记录: |