Using WMS services in R
How to use WMS (raster) GIS services within R scripts
WMS stands for Web Map Service. The service provides prerendered tiles at different scales. This makes it useful to include them as background images in maps.
We will use the leaflet
package to make interactive maps.
library(leaflet)
First, we define some WMS URLs for Flanders and Belgium to play with:
# Flanders:
wms_grb <- "https://geo.api.vlaanderen.be/GRB-basiskaart/wms"
wms_ortho <- "https://geo.api.vlaanderen.be/OMWRGBMRVL/wms"
wms_inbo <- "https://geo.api.vlaanderen.be/INBO/wms"
wms_hunting <- "https://geo.api.vlaanderen.be/Jacht/wms"
# Belgium:
wms_cartoweb_be <- "https://cartoweb.wms.ngi.be/service"
wms_ortho_be <- "https://wms.ngi.be/inspire/ortho/service"
-
wms_grb
links to the WMS of the GRB-basiskaart, the Flemish cadastral map. It depicts land parcels, buildings, watercourses, roads and railroads. -
wms_ortho
contains a mosaic of recent orthophotos made during the winter. The layerOrtho
contains the images, the layerVliegdagcontour
detail on the time when the pictures were taken. -
wms_inbo
is a WMS providing several layers. -
wms_hunting
displays hunting grounds in Flanders. -
wms_cartoweb_be
provides several cartographic layers from the National Geographic Institute (NGI). -
wms_ortho_be
provides recent orthophotos for the whole Belgian territory, compiled by NGI.
In the WFS tutorial, we present a handy overview of websites with WMS (and WFS) services.
Simple maps
WMS layers can be added to a leaflet
map using the addWMSTiles()
function.
It is required to define the map view with setView()
, by providing a
map center (as longitude and latitude coordinates) and a zoom level.
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 15) %>%
addWMSTiles(
wms_grb,
layers = "GRB_BSK",
options = WMSTileOptions(format = "image/png", transparent = TRUE)
)
data:image/s3,"s3://crabby-images/c7d0e/c7d0ef3148d4386ad509c1d7a916668adab7833c" alt="Leaflet map with the GRB-basiskaart as background"
Note: run the code to see this and the following interactive maps.
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 15) %>%
addWMSTiles(
wms_ortho,
layers = "Ortho",
options = WMSTileOptions(format = "image/png", transparent = TRUE)
)
data:image/s3,"s3://crabby-images/e3d71/e3d71ee7c7a4c8e1e1818a24449d09fe89ed1e25" alt="Leaflet map with the orthophoto mosaic as background"
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 15) %>%
addWMSTiles(
wms_inbo,
layers = "PNVeg",
options = WMSTileOptions(format = "image/png", transparent = TRUE)
)
data:image/s3,"s3://crabby-images/ef080/ef08079ef76c7a5eb4d2d4b6cc2b535c185f0621" alt="Leaflet map with the potential natural vegetation"
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 15) %>%
addWMSTiles(
wms_cartoweb_be,
layers = "topo",
options = WMSTileOptions(format = "image/png")
)
data:image/s3,"s3://crabby-images/2d0ee/2d0ee7df96fcf0c825533fd6991af94049930912" alt="Leaflet map of the topographic CartoWeb layer. At zoom level 15."
Setting another zoom level of the CartoWeb service triggers the display of another topographic map. Of course you can do that interactively with the above map (not supported on this web site though).
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 12) %>%
addWMSTiles(
wms_cartoweb_be,
layers = "topo",
options = WMSTileOptions(format = "image/png")
)
data:image/s3,"s3://crabby-images/108be/108be92213322d23e072c90571c754622b47572d" alt="Leaflet map of the topographic CartoWeb layer. At zoom level 12."
Combining multiple layers
Below, we also add OpenStreetMap in the background.
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 14) %>%
addTiles(group = "OSM") %>%
addWMSTiles(
wms_hunting,
layers = "Jachtterr",
options = WMSTileOptions(format = "image/png", transparent = TRUE)
)
data:image/s3,"s3://crabby-images/5aa31/5aa31dd938e32cfbfe5b3154b1cd4814f083c906" alt="Leaflet map of hunting grounds with the OpenStreetMap in the background"
By adding addWMSTiles()
multiple times, several WMSs can be displayed
on top of each other.
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 14) %>%
addTiles(group = "OSM") %>%
addWMSTiles(
wms_grb,
layers = "GRB_BSK",
options = WMSTileOptions(format = "image/png", transparent = TRUE),
group = "GRB"
) %>%
addWMSTiles(
wms_hunting,
layers = "Jachtterr",
options = WMSTileOptions(format = "image/png", transparent = TRUE),
group = "hunting<br>grounds"
) %>%
addLayersControl(
baseGroups = "OSM",
overlayGroups = c("GRB", "hunting<br>grounds"),
options = layersControlOptions(collapsed = FALSE)
)
data:image/s3,"s3://crabby-images/8cc3c/8cc3c80cbb66ec524c28809868f319cd1f60dd0d" alt="Leaflet map with the GRB-basiskaart, hunting ground and the OpenStreetMap (OSM) as background"
The overlay
layer of the NGI CartoWeb service is aimed at higher zoom
levels and is useful to put on top of a map. Here we take the NGI
orthophoto service as a background map. We must set the overlay
layer
transparent in order to see the layers below – the default option being
transparent = FALSE
.
leaflet() %>%
setView(lng = 4.287638, lat = 50.703039, zoom = 16) %>%
addWMSTiles(
wms_ortho_be,
layers = "orthoimage_coverage",
group = "Orthophoto BE") %>%
addWMSTiles(
wms_cartoweb_be,
layers = "overlay",
options = WMSTileOptions(format = "image/png", transparent = TRUE),
group = "Topo BE"
) %>%
addLayersControl(
baseGroups = "Orthophoto BE",
overlayGroups = "Topo BE"
)
data:image/s3,"s3://crabby-images/bd0bc/bd0bcd07130e3463b8b51cd0c6e3d8e29cf02e9f" alt="Leaflet map with the Belgian orthophoto mosaic as background and a topographic overlay on top"