rmapzen is a client for any implementation of the Mapzen
API. Though Mapzen itself has gone out of business,
rmapzen can be set up to work with any provider who hosts
Mapzen’s open-source software, including geocode.earth, Nextzen, and NYC GeoSearch from NYC
Planning Labs. For more information, see https://www.mapzen.com/documentation/.
The project is available
on github as well as CRAN.
rmapzen provides access to the following Mapzen API
services:
rmapzen works with API providers who implement the
Mapzen API. In order to specify provider information (such as URL and
API key), use mz_set_host. There are custom set-up
functions for the following providers:
mz_set_search_host_geocode.earthmz_set_tile_host_nextzen.mz_set_search_host_nyc_geosearch.As of this writing, there are no public providers offering the Mapzen isochrone service.
All of the services in Mapzen search have been implemented. Search functions:
mz_searchmz_reverse_geocodemz_autocompletemz_placemz_structured_search (what’s
this?)Each of those functions returns a mapzen_geo_list. The
sample dataset oakland_public contains the results of
mz_search("Oakland public library branch") on January 8,
2017:
#> GeoJSON response from Mapzen
#> Attribution info: https://search.mapzen.com/v1/attribution 
#> Bounds (lon/lat): (-122.29, 37.74) - (-122.17, 37.85)
#> 25 locations:
#>    Oakland Public Library - Temescal Branch (-122.26, 37.84)
#>    Oakland Public Library - Rockridge Branch (-122.25, 37.84)
#>    Lakeview Branch Oakland Public Library (-122.25, 37.81)
#>    Golden Gate Branch Oakland Public Library (-122.28, 37.84)
#>    Brookfield Village Branch Oakland Public Library (-122.19, 37.74)
#>   ...mz_bbox(oakland_public)
#> # A tibble: 1 × 4
#>   min_lon min_lat max_lon max_lat
#>     <dbl>   <dbl>   <dbl>   <dbl>
#> 1   -122.    37.7   -122.    37.8
as.data.frame(oakland_public)
#> # A tibble: 25 × 26
#>    id           gid   layer source sourc…¹ name  house…² confi…³ accur…⁴ country
#>    <chr>        <chr> <chr> <chr>  <chr>   <chr> <chr>     <dbl> <chr>   <chr>  
#>  1 way:1256861… open… venue opens… way:12… Oakl… 5205      0.926 point   United…
#>  2 way:43255308 open… venue opens… way:43… Oakl… <NA>      0.926 point   United…
#>  3 way:36977219 open… venue opens… way:36… Lake… <NA>      0.664 point   United…
#>  4 5352843      geon… venue geona… 5352843 Gold… <NA>      0.663 point   United…
#>  5 node:368169… open… venue opens… node:3… Broo… <NA>      0.663 point   United…
#>  6 way:43919891 open… venue opens… way:43… West… 1801      0.663 point   United…
#>  7 node:368169… open… venue opens… node:3… Elmh… <NA>      0.663 point   United…
#>  8 node:368169… open… venue opens… node:3… Mont… <NA>      0.663 point   United…
#>  9 way:28376124 open… venue opens… way:28… Main… 125       0.663 point   United…
#> 10 node:368169… open… venue opens… node:3… Lati… <NA>      0.663 point   United…
#> # … with 15 more rows, 16 more variables: country_gid <chr>, country_a <chr>,
#> #   region <chr>, region_gid <chr>, region_a <chr>, county <chr>,
#> #   county_gid <chr>, locality <chr>, locality_gid <chr>, neighbourhood <chr>,
#> #   neighbourhood_gid <chr>, label <chr>, street <chr>, postalcode <chr>,
#> #   lon <dbl>, lat <dbl>, and abbreviated variable names ¹source_id,
#> #   ²housenumber, ³confidence, ⁴accuracySearch can, optionally, be constrained to a particular country, data
layer, boundary rectangle, or boundary circle. Furthermore, search can
prioritize results near a given “focus” point. See
?mz_search.
rmapzen provides an interface to Mapzen’s vector tiles
service. Tile requests can be specified using the x, y, zoom
coordinates of the tile service, as well as with a lat/long bounding
box. Multiple tiles are stitched together and returned as an object of
class mz_vector_tiles. See ?mz_vector_tiles.
The sample data set ca_tiles contains zoomed out vector
tile data for all of California as well as parts of neighboring
states.
ca_tiles
#> Mapzen vector tile data
#> Layers: (count of features in parentheses)
#>     water (144)
#>     buildings (0)
#>     places (28)
#>     transit (10)
#>     pois (30)
#>     boundaries (22)
#>     roads (308)
#>     earth (4)
#>     landuse (176)Each element of a vector tile response includes point, line, and/or
polygon data for an individual map layer, and has class
mapzen_vector_layer. Like other response types, the
mapzen_vector_layer can be converted to sf and
sp objects for further processing, using the generic
functions as_sf and as_sp.
# points of interest
as_sf(ca_tiles$pois)
#> Registered S3 method overwritten by 'geojsonsf':
#>   method        from   
#>   print.geojson geojson
#> Simple feature collection with 30 features and 11 fields
#> Geometry type: POINT
#> Dimension:     XY
#> Bounding box:  xmin: -123.536 ymin: 32.009 xmax: -112.58 ymax: 48.808
#> Geodetic CRS:  WGS 84
#> # A tibble: 30 × 12
#>    kind   prote…¹ area  opera…² name:…³ source min_z…⁴ tier  osm_r…⁵ name  id   
#>    <chr>  <chr>   <chr> <chr>   <chr>   <chr>  <chr>   <chr> <chr>   <chr> <chr>
#>  1 natio… 2       1377… United… <NA>    opens… 5.58    1     TRUE    Crat… 5471…
#>  2 natio… 2       2035… United… <NA>    opens… 5.29    1     TRUE    Moun… 6c47…
#>  3 natio… 2       2132… United… Nation… opens… 3.6     1     TRUE    Deat… 4e80…
#>  4 natio… 2       2543… United… <NA>    opens… 5.13    1     TRUE    Crat… a710…
#>  5 natio… 2       2552… United… Sequoi… opens… 5.13    1     TRUE    Sequ… e7fc…
#>  6 natio… 2       2740… United… Nation… opens… 5.08    1     TRUE    Nort… 7bfb…
#>  7 natio… 2       2812… United… Kings-… opens… 5.06    1     TRUE    King… 553d…
#>  8 natio… 2       4671… United… Joshua… opens… 4.7     1     TRUE    Josh… 09bc…
#>  9 natio… 2       4858… United… Yosemi… opens… 4.67    1     TRUE    Yose… 4815…
#> 10 natio… 2       7790… United… Olympi… opens… 4.33    1     TRUE    Olym… e1e8…
#> # … with 20 more rows, 1 more variable: geometry <POINT [°]>, and abbreviated
#> #   variable names ¹protect_class, ²operator, ³`name:de`, ⁴min_zoom,
#> #   ⁵osm_relationsf and Spatial*DataFrame conversionAny object returned by a Mapzen service can be converted to the
appropriate Spatial*DataFrame or sf object
using the generics as_sp and as_sf, for easy
interoperability with other packages. You can also convert most objects
directly to data frames, allowing for use within tidy pipelines:
library(dplyr)
library(sf)
as_sf(oakland_public) %>%
    select(name, confidence, region, locality, neighbourhood)
#> Simple feature collection with 25 features and 5 fields
#> Geometry type: POINT
#> Dimension:     XY
#> Bounding box:  xmin: -122.2854 ymin: 37.73742 xmax: -122.1749 ymax: 37.84632
#> Geodetic CRS:  WGS 84
#> # A tibble: 25 × 6
#>    name                 confi…¹ region local…² neigh…³             geometry
#>    <chr>                  <dbl> <chr>  <chr>   <chr>            <POINT [°]>
#>  1 Oakland Public Libr…   0.926 Calif… Oakland Shafter (-122.2625 37.83824)
#>  2 Oakland Public Libr…   0.926 Calif… Oakland Rockri…    (-122.2511 37.84)
#>  3 Lakeview Branch Oak…   0.664 Calif… Oakland <NA>     (-122.249 37.80919)
#>  4 Golden Gate Branch …   0.663 Calif… Oakland Gaskill (-122.2822 37.83937)
#>  5 Brookfield Village …   0.663 Calif… Oakland South … (-122.1886 37.73742)
#>  6 West Oakland Branch…   0.663 Calif… Oakland Ralph … (-122.2854 37.81296)
#>  7 Elmhurst Branch Oak…   0.663 Calif… Oakland Webster (-122.1749 37.75154)
#>  8 Montclair Branch Oa…   0.663 Calif… Oakland Montcl… (-122.2141 37.83204)
#>  9 Main Branch Oakland…   0.663 Calif… Oakland Civic … (-122.2638 37.80101)
#> 10 Latin American Bran…   0.663 Calif… Oakland St. El… (-122.2225 37.78354)
#> # … with 15 more rows, and abbreviated variable names ¹confidence, ²locality,
#> #   ³neighbourhoodCurrently, the following methods are available to pull out commonly used pieces of a response:
mz_coordinates (only available for search results):
extracts lat/lon coordinates from search results, and returns them as a
data.frame.mz_bbox: returns the bounding box of an object as a
data.frame with columns min_lon,
min_lat, max_lon, and
max_lat.