Title: | Interactive Maps with 'Mapbox GL JS' and 'MapLibre GL JS' |
---|---|
Description: | Provides an interface to the 'Mapbox GL JS' (<https://docs.mapbox.com/mapbox-gl-js/guides>) and the 'MapLibre GL JS' (<https://maplibre.org/maplibre-gl-js/docs/>) interactive mapping libraries to help users create custom interactive maps in R. Users can create interactive globe visualizations; layer 'sf' objects to create filled maps, circle maps, 'heatmaps', and three-dimensional graphics; and customize map styles and views. The package also includes utilities to use 'Mapbox' and 'MapLibre' maps in 'Shiny' web applications. |
Authors: | Kyle Walker [aut, cre] |
Maintainer: | Kyle Walker <[email protected]> |
License: | MIT + file LICENSE |
Version: | 0.2.1 |
Built: | 2025-03-18 14:23:13 UTC |
Source: | https://github.com/walkerke/mapgl |
This function adds a categorical legend to a Mapbox GL map. It supports customizable colors, sizes, and shapes for legend items.
add_categorical_legend( map, legend_title, values, colors, circular_patches = FALSE, position = "top-left", unique_id = NULL, sizes = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
add_categorical_legend( map, legend_title, values, colors, circular_patches = FALSE, position = "top-left", unique_id = NULL, sizes = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
map |
A map object created by the |
legend_title |
The title of the legend. |
values |
A vector of categories or values to be displayed in the legend. |
colors |
The corresponding colors for the values. Can be a vector of colors or a single color. |
circular_patches |
Logical, whether to use circular patches in the legend. Default is FALSE. |
position |
The position of the legend on the map. One of "top-left", "bottom-left", "top-right", "bottom-right". Default is "top-left". |
unique_id |
A unique ID for the legend container. If NULL, a random ID will be generated. |
sizes |
An optional numeric vector of sizes for the legend patches, or a single numeric value. If provided as a vector, it should have the same length as |
add |
Logical, whether to add this legend to existing legends (TRUE) or replace existing legends (FALSE). Default is FALSE. |
width |
The width of the legend. Can be specified in pixels (e.g., "250px") or as "auto". Default is NULL, which uses the built-in default. |
layer_id |
The ID of the layer that this legend is associated with. If provided, the legend will be shown/hidden when the layer visibility is toggled. |
margin_top |
Custom top margin in pixels, allowing for fine control over legend positioning. Default is NULL (uses standard positioning). |
margin_right |
Custom right margin in pixels. Default is NULL. |
margin_bottom |
Custom bottom margin in pixels. Default is NULL. |
margin_left |
Custom left margin in pixels. Default is NULL. |
The updated map object with the legend added.
## Not run: library(mapboxgl) map <- mapboxgl( center = c(-96, 37.8), zoom = 3 ) map %>% add_categorical_legend( legend_title = "Population", values = c("Low", "Medium", "High"), colors = c("#FED976", "#FEB24C", "#FD8D3C"), circular_patches = TRUE, sizes = c(10, 15, 20), width = "300px" ) ## End(Not run)
## Not run: library(mapboxgl) map <- mapboxgl( center = c(-96, 37.8), zoom = 3 ) map %>% add_categorical_legend( legend_title = "Population", values = c("Low", "Medium", "High"), colors = c("#FED976", "#FEB24C", "#FD8D3C"), circular_patches = TRUE, sizes = c(10, 15, 20), width = "300px" ) ## End(Not run)
Add a circle layer to a Mapbox GL map
add_circle_layer( map, id, source, source_layer = NULL, circle_blur = NULL, circle_color = NULL, circle_opacity = NULL, circle_radius = NULL, circle_sort_key = NULL, circle_stroke_color = NULL, circle_stroke_opacity = NULL, circle_stroke_width = NULL, circle_translate = NULL, circle_translate_anchor = "map", visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL, cluster_options = NULL )
add_circle_layer( map, id, source, source_layer = NULL, circle_blur = NULL, circle_color = NULL, circle_opacity = NULL, circle_radius = NULL, circle_sort_key = NULL, circle_stroke_color = NULL, circle_stroke_opacity = NULL, circle_stroke_width = NULL, circle_translate = NULL, circle_translate_anchor = "map", visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL, cluster_options = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
circle_blur |
Amount to blur the circle. |
circle_color |
The color of the circle. |
circle_opacity |
The opacity at which the circle will be drawn. |
circle_radius |
Circle radius. |
circle_sort_key |
Sorts features in ascending order based on this value. |
circle_stroke_color |
The color of the circle's stroke. |
circle_stroke_opacity |
The opacity of the circle's stroke. |
circle_stroke_width |
The width of the circle's stroke. |
circle_translate |
The geometry's offset. Values are |
circle_translate_anchor |
Controls the frame of reference for |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
cluster_options |
A list of options for clustering circles, created by the |
The modified map object with the new circle layer added.
## Not run: library(mapgl) library(sf) library(dplyr) # Set seed for reproducibility set.seed(1234) # Define the bounding box for Washington DC (approximately) bbox <- st_bbox( c( xmin = -77.119759, ymin = 38.791645, xmax = -76.909393, ymax = 38.995548 ), crs = st_crs(4326) ) # Generate 30 random points within the bounding box random_points <- st_as_sf( data.frame( id = 1:30, lon = runif(30, bbox["xmin"], bbox["xmax"]), lat = runif(30, bbox["ymin"], bbox["ymax"]) ), coords = c("lon", "lat"), crs = 4326 ) # Assign random categories categories <- c("music", "bar", "theatre", "bicycle") random_points <- random_points %>% mutate(category = sample(categories, n(), replace = TRUE)) # Map with circle layer mapboxgl(style = mapbox_style("light")) %>% fit_bounds(random_points, animate = FALSE) %>% add_circle_layer( id = "poi-layer", source = random_points, circle_color = match_expr( "category", values = c( "music", "bar", "theatre", "bicycle" ), stops = c( "#1f78b4", "#33a02c", "#e31a1c", "#ff7f00" ) ), circle_radius = 8, circle_stroke_color = "#ffffff", circle_stroke_width = 2, circle_opacity = 0.8, tooltip = "category", hover_options = list( circle_radius = 12, circle_color = "#ffff99" ) ) %>% add_categorical_legend( legend_title = "Points of Interest", values = c("Music", "Bar", "Theatre", "Bicycle"), colors = c("#1f78b4", "#33a02c", "#e31a1c", "#ff7f00"), circular_patches = TRUE ) ## End(Not run)
## Not run: library(mapgl) library(sf) library(dplyr) # Set seed for reproducibility set.seed(1234) # Define the bounding box for Washington DC (approximately) bbox <- st_bbox( c( xmin = -77.119759, ymin = 38.791645, xmax = -76.909393, ymax = 38.995548 ), crs = st_crs(4326) ) # Generate 30 random points within the bounding box random_points <- st_as_sf( data.frame( id = 1:30, lon = runif(30, bbox["xmin"], bbox["xmax"]), lat = runif(30, bbox["ymin"], bbox["ymax"]) ), coords = c("lon", "lat"), crs = 4326 ) # Assign random categories categories <- c("music", "bar", "theatre", "bicycle") random_points <- random_points %>% mutate(category = sample(categories, n(), replace = TRUE)) # Map with circle layer mapboxgl(style = mapbox_style("light")) %>% fit_bounds(random_points, animate = FALSE) %>% add_circle_layer( id = "poi-layer", source = random_points, circle_color = match_expr( "category", values = c( "music", "bar", "theatre", "bicycle" ), stops = c( "#1f78b4", "#33a02c", "#e31a1c", "#ff7f00" ) ), circle_radius = 8, circle_stroke_color = "#ffffff", circle_stroke_width = 2, circle_opacity = 0.8, tooltip = "category", hover_options = list( circle_radius = 12, circle_color = "#ffff99" ) ) %>% add_categorical_legend( legend_title = "Points of Interest", values = c("Music", "Bar", "Theatre", "Bicycle"), colors = c("#1f78b4", "#33a02c", "#e31a1c", "#ff7f00"), circular_patches = TRUE ) ## End(Not run)
Add a continuous legend
add_continuous_legend( map, legend_title, values, colors, position = "top-left", unique_id = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
add_continuous_legend( map, legend_title, values, colors, position = "top-left", unique_id = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
map |
A map object created by the |
legend_title |
The title of the legend. |
values |
The values being represented on the map (vector of stops). |
colors |
The colors used to generate the color ramp. |
position |
The position of the legend on the map (one of "top-left", "bottom-left", "top-right", "bottom-right"). |
unique_id |
A unique ID for the legend container. Defaults to NULL. |
add |
Logical, whether to add this legend to existing legends (TRUE) or replace existing legends (FALSE). Default is FALSE. |
width |
The width of the legend. Can be specified in pixels (e.g., "250px") or as "auto". Default is NULL, which uses the built-in default. |
layer_id |
The ID of the layer that this legend is associated with. If provided, the legend will be shown/hidden when the layer visibility is toggled. |
margin_top |
Custom top margin in pixels, allowing for fine control over legend positioning. Default is NULL (uses standard positioning). |
margin_right |
Custom right margin in pixels. Default is NULL. |
margin_bottom |
Custom bottom margin in pixels. Default is NULL. |
margin_left |
Custom left margin in pixels. Default is NULL. |
The updated map object with the legend added.
Add a draw control to a map
add_draw_control( map, position = "top-left", freehand = FALSE, simplify_freehand = FALSE, orientation = "vertical", ... )
add_draw_control( map, position = "top-left", freehand = FALSE, simplify_freehand = FALSE, orientation = "vertical", ... )
map |
A map object created by the |
position |
A string specifying the position of the draw control. One of "top-right", "top-left", "bottom-right", or "bottom-left". |
freehand |
Logical, whether to enable freehand drawing mode. Default is FALSE. |
simplify_freehand |
Logical, whether to apply simplification to freehand drawings. Default is FALSE. |
orientation |
A string specifying the orientation of the draw control. Either "vertical" (default) or "horizontal". |
... |
Additional named arguments. See https://github.com/mapbox/mapbox-gl-draw/blob/main/docs/API.md#options for a list of options. |
The modified map object with the draw control added.
## Not run: library(mapgl) mapboxgl( style = mapbox_style("streets"), center = c(-74.50, 40), zoom = 9 ) |> add_draw_control() ## End(Not run)
## Not run: library(mapgl) mapboxgl( style = mapbox_style("streets"), center = c(-74.50, 40), zoom = 9 ) |> add_draw_control() ## End(Not run)
Add a fill-extrusion layer to a Mapbox GL map
add_fill_extrusion_layer( map, id, source, source_layer = NULL, fill_extrusion_base = NULL, fill_extrusion_color = NULL, fill_extrusion_height = NULL, fill_extrusion_opacity = NULL, fill_extrusion_pattern = NULL, fill_extrusion_translate = NULL, fill_extrusion_translate_anchor = "map", visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
add_fill_extrusion_layer( map, id, source, source_layer = NULL, fill_extrusion_base = NULL, fill_extrusion_color = NULL, fill_extrusion_height = NULL, fill_extrusion_opacity = NULL, fill_extrusion_pattern = NULL, fill_extrusion_translate = NULL, fill_extrusion_translate_anchor = "map", visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
fill_extrusion_base |
The base height of the fill extrusion. |
fill_extrusion_color |
The color of the fill extrusion. |
fill_extrusion_height |
The height of the fill extrusion. |
fill_extrusion_opacity |
The opacity of the fill extrusion. |
fill_extrusion_pattern |
Name of image in sprite to use for drawing image fills. |
fill_extrusion_translate |
The geometry's offset. Values are |
fill_extrusion_translate_anchor |
Controls the frame of reference for |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
The modified map object with the new fill-extrusion layer added.
## Not run: library(mapgl) maplibre( style = maptiler_style("basic"), center = c(-74.0066, 40.7135), zoom = 15.5, pitch = 45, bearing = -17.6 ) |> add_vector_source( id = "openmaptiles", url = paste0( "https://api.maptiler.com/tiles/v3/tiles.json?key=", Sys.getenv("MAPTILER_API_KEY") ) ) |> add_fill_extrusion_layer( id = "3d-buildings", source = "openmaptiles", source_layer = "building", fill_extrusion_color = interpolate( column = "render_height", values = c(0, 200, 400), stops = c("lightgray", "royalblue", "lightblue") ), fill_extrusion_height = list( "interpolate", list("linear"), list("zoom"), 15, 0, 16, list("get", "render_height") ) ) ## End(Not run)
## Not run: library(mapgl) maplibre( style = maptiler_style("basic"), center = c(-74.0066, 40.7135), zoom = 15.5, pitch = 45, bearing = -17.6 ) |> add_vector_source( id = "openmaptiles", url = paste0( "https://api.maptiler.com/tiles/v3/tiles.json?key=", Sys.getenv("MAPTILER_API_KEY") ) ) |> add_fill_extrusion_layer( id = "3d-buildings", source = "openmaptiles", source_layer = "building", fill_extrusion_color = interpolate( column = "render_height", values = c(0, 200, 400), stops = c("lightgray", "royalblue", "lightblue") ), fill_extrusion_height = list( "interpolate", list("linear"), list("zoom"), 15, 0, 16, list("get", "render_height") ) ) ## End(Not run)
Add a fill layer to a map
add_fill_layer( map, id, source, source_layer = NULL, fill_antialias = TRUE, fill_color = NULL, fill_emissive_strength = NULL, fill_opacity = NULL, fill_outline_color = NULL, fill_pattern = NULL, fill_sort_key = NULL, fill_translate = NULL, fill_translate_anchor = "map", fill_z_offset = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
add_fill_layer( map, id, source, source_layer = NULL, fill_antialias = TRUE, fill_color = NULL, fill_emissive_strength = NULL, fill_opacity = NULL, fill_outline_color = NULL, fill_pattern = NULL, fill_sort_key = NULL, fill_translate = NULL, fill_translate_anchor = "map", fill_z_offset = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
fill_antialias |
Whether or not the fill should be antialiased. |
fill_color |
The color of the filled part of this layer. |
fill_emissive_strength |
Controls the intensity of light emitted on the source features. |
fill_opacity |
The opacity of the entire fill layer. |
fill_outline_color |
The outline color of the fill. |
fill_pattern |
Name of image in sprite to use for drawing image fills. |
fill_sort_key |
Sorts features in ascending order based on this value. |
fill_translate |
The geometry's offset. Values are |
fill_translate_anchor |
Controls the frame of reference for |
fill_z_offset |
Specifies an uniform elevation in meters. |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
The modified map object with the new fill layer added.
## Not run: library(tidycensus) fl_age <- get_acs( geography = "tract", variables = "B01002_001", state = "FL", year = 2022, geometry = TRUE ) mapboxgl() |> fit_bounds(fl_age, animate = FALSE) |> add_fill_layer( id = "fl_tracts", source = fl_age, fill_color = interpolate( column = "estimate", values = c(20, 80), stops = c("lightblue", "darkblue"), na_color = "lightgrey" ), fill_opacity = 0.5 ) ## End(Not run)
## Not run: library(tidycensus) fl_age <- get_acs( geography = "tract", variables = "B01002_001", state = "FL", year = 2022, geometry = TRUE ) mapboxgl() |> fit_bounds(fl_age, animate = FALSE) |> add_fill_layer( id = "fl_tracts", source = fl_age, fill_color = interpolate( column = "estimate", values = c(20, 80), stops = c("lightblue", "darkblue"), na_color = "lightgrey" ), fill_opacity = 0.5 ) ## End(Not run)
Add a fullscreen control to a map
add_fullscreen_control(map, position = "top-right")
add_fullscreen_control(map, position = "top-right")
map |
A map object created by the |
position |
A string specifying the position of the fullscreen control. One of "top-right", "top-left", "bottom-right", or "bottom-left". |
The modified map object with the fullscreen control added.
## Not run: library(mapgl) maplibre( style = maptiler_style("streets"), center = c(11.255, 43.77), zoom = 13 ) |> add_fullscreen_control(position = "top-right") ## End(Not run)
## Not run: library(mapgl) maplibre( style = maptiler_style("streets"), center = c(11.255, 43.77), zoom = 13 ) |> add_fullscreen_control(position = "top-right") ## End(Not run)
This function adds a Geocoder search bar to a Mapbox GL or MapLibre GL map.
By default, a marker will be added at the selected location and the map will
fly to that location. The results of the geocode are accessible in a Shiny
session at input$MAPID_geocoder$result
, where MAPID
is the name of your map.
add_geocoder_control( map, position = "top-right", placeholder = "Search", collapsed = FALSE, ... )
add_geocoder_control( map, position = "top-right", placeholder = "Search", collapsed = FALSE, ... )
map |
A map object created by the |
position |
The position of the control. Can be one of "top-left", "top-right", "bottom-left", or "bottom-right". Default is "top-right". |
placeholder |
A string to use as placeholder text for the search bar. Default is "Search". |
collapsed |
Whether the control should be collapsed until hovered or clicked. Default is FALSE. |
... |
Additional parameters to pass to the Geocoder. |
The modified map object with the geocoder control added.
## Not run: library(mapgl) mapboxgl() |> add_geocoder_control(position = "top-left", placeholder = "Enter an address") maplibre() |> add_geocoder_control(position = "top-right", placeholder = "Search location") ## End(Not run)
## Not run: library(mapgl) mapboxgl() |> add_geocoder_control(position = "top-left", placeholder = "Enter an address") maplibre() |> add_geocoder_control(position = "top-right", placeholder = "Search location") ## End(Not run)
This function adds a Geolocate control to a Mapbox GL or MapLibre GL map. The geolocate control allows users to track their current location on the map.
add_geolocate_control( map, position = "top-right", track_user = FALSE, show_accuracy_circle = TRUE, show_user_location = TRUE, show_user_heading = FALSE, fit_bounds_options = list(maxZoom = 15), position_options = list(enableHighAccuracy = FALSE, timeout = 6000) )
add_geolocate_control( map, position = "top-right", track_user = FALSE, show_accuracy_circle = TRUE, show_user_location = TRUE, show_user_heading = FALSE, fit_bounds_options = list(maxZoom = 15), position_options = list(enableHighAccuracy = FALSE, timeout = 6000) )
map |
A map object created by the |
position |
The position of the control. Can be one of "top-left", "top-right", "bottom-left", or "bottom-right". Default is "top-right". |
track_user |
Whether to actively track the user's location. If TRUE, the map will continuously update as the user moves. Default is FALSE. |
show_accuracy_circle |
Whether to show a circle indicating the accuracy of the location. Default is TRUE. |
show_user_location |
Whether to show a dot at the user's location. Default is TRUE. |
show_user_heading |
Whether to show an arrow indicating the device's heading when tracking location. Only works when track_user is TRUE. Default is FALSE. |
fit_bounds_options |
A list of options for fitting bounds when panning to the user's location. Default maxZoom is 15. |
position_options |
A list of Geolocation API position options. Default has enableHighAccuracy=FALSE and timeout=6000. |
The modified map object with the geolocate control added.
## Not run: library(mapgl) mapboxgl() |> add_geolocate_control( position = "top-right", track_user = TRUE, show_user_heading = TRUE ) ## End(Not run)
## Not run: library(mapgl) mapboxgl() |> add_geolocate_control( position = "top-right", track_user = TRUE, show_user_heading = TRUE ) ## End(Not run)
This function adds a globe minimap control to a Mapbox GL or Maplibre map.
add_globe_minimap( map, position = "bottom-right", globe_size = 82, land_color = "white", water_color = "rgba(30 40 70/60%)", marker_color = "#ff2233", marker_size = 1 )
add_globe_minimap( map, position = "bottom-right", globe_size = 82, land_color = "white", water_color = "rgba(30 40 70/60%)", marker_color = "#ff2233", marker_size = 1 )
map |
A |
position |
A string specifying the position of the minimap. |
globe_size |
Number of pixels for the diameter of the globe. Default is 82. |
land_color |
HTML color to use for land areas on the globe. Default is 'white'. |
water_color |
HTML color to use for water areas on the globe. Default is 'rgba(30 40 70/60%)'. |
marker_color |
HTML color to use for the center point marker. Default is '#ff2233'. |
marker_size |
Scale ratio for the center point marker. Default is 1. |
The modified map object with the globe minimap added.
## Not run: library(mapgl) m <- mapboxgl() %>% add_globe_minimap() m <- maplibre() %>% add_globe_minimap() ## End(Not run)
## Not run: library(mapgl) m <- mapboxgl() %>% add_globe_minimap() m <- maplibre() %>% add_globe_minimap() ## End(Not run)
Add a hexagon source from the H3 geospatial indexing system.
add_h3j_source(map, id, url)
add_h3j_source(map, id, url)
map |
A map object created by the |
id |
A unique ID for the source. |
url |
A URL pointing to the vector tile source. |
https://h3geo.org, https://github.com/INSPIDE/h3j-h3t
url = "https://inspide.github.io/h3j-h3t/examples/h3j/sample.h3j" maplibre(center=c(-3.704, 40.417), zoom=15, pitch=30) |> add_h3j_source("h3j_testsource", url = url ) |> add_fill_extrusion_layer( id = "h3j_testlayer", source = "h3j_testsource", fill_extrusion_color = interpolate( column = "value", values = c(0, 21.864), stops = c("#430254", "#f83c70") ), fill_extrusion_height = list( "interpolate", list("linear"), list("zoom"), 14, 0, 15.05, list("*", 10, list("get", "value")) ), fill_extrusion_opacity = 0.7 )
url = "https://inspide.github.io/h3j-h3t/examples/h3j/sample.h3j" maplibre(center=c(-3.704, 40.417), zoom=15, pitch=30) |> add_h3j_source("h3j_testsource", url = url ) |> add_fill_extrusion_layer( id = "h3j_testlayer", source = "h3j_testsource", fill_extrusion_color = interpolate( column = "value", values = c(0, 21.864), stops = c("#430254", "#f83c70") ), fill_extrusion_height = list( "interpolate", list("linear"), list("zoom"), 14, 0, 15.05, list("*", 10, list("get", "value")) ), fill_extrusion_opacity = 0.7 )
Add a heatmap layer to a Mapbox GL map
add_heatmap_layer( map, id, source, source_layer = NULL, heatmap_color = NULL, heatmap_intensity = NULL, heatmap_opacity = NULL, heatmap_radius = NULL, heatmap_weight = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, before_id = NULL, filter = NULL )
add_heatmap_layer( map, id, source, source_layer = NULL, heatmap_color = NULL, heatmap_intensity = NULL, heatmap_opacity = NULL, heatmap_radius = NULL, heatmap_weight = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, before_id = NULL, filter = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
heatmap_color |
The color of the heatmap points. |
heatmap_intensity |
The intensity of the heatmap points. |
heatmap_opacity |
The opacity of the heatmap layer. |
heatmap_radius |
The radius of influence of each individual heatmap point. |
heatmap_weight |
The weight of each individual heatmap point. |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
The modified map object with the new heatmap layer added.
## Not run: library(mapgl) mapboxgl( style = mapbox_style("dark"), center = c(-120, 50), zoom = 2 ) |> add_heatmap_layer( id = "earthquakes-heat", source = list( type = "geojson", data = "https://docs.mapbox.com/mapbox-gl-js/assets/earthquakes.geojson" ), heatmap_weight = interpolate( column = "mag", values = c(0, 6), stops = c(0, 1) ), heatmap_intensity = interpolate( property = "zoom", values = c(0, 9), stops = c(1, 3) ), heatmap_color = interpolate( property = "heatmap-density", values = seq(0, 1, 0.2), stops = c( "rgba(33,102,172,0)", "rgb(103,169,207)", "rgb(209,229,240)", "rgb(253,219,199)", "rgb(239,138,98)", "rgb(178,24,43)" ) ), heatmap_opacity = 0.7 ) ## End(Not run)
## Not run: library(mapgl) mapboxgl( style = mapbox_style("dark"), center = c(-120, 50), zoom = 2 ) |> add_heatmap_layer( id = "earthquakes-heat", source = list( type = "geojson", data = "https://docs.mapbox.com/mapbox-gl-js/assets/earthquakes.geojson" ), heatmap_weight = interpolate( column = "mag", values = c(0, 6), stops = c(0, 1) ), heatmap_intensity = interpolate( property = "zoom", values = c(0, 9), stops = c(1, 3) ), heatmap_color = interpolate( property = "heatmap-density", values = seq(0, 1, 0.2), stops = c( "rgba(33,102,172,0)", "rgb(103,169,207)", "rgb(209,229,240)", "rgb(253,219,199)", "rgb(239,138,98)", "rgb(178,24,43)" ) ), heatmap_opacity = 0.7 ) ## End(Not run)
This function adds an image to the map's style. The image can be used with icon-image, background-pattern, fill-pattern, or line-pattern.
add_image( map, id, url, content = NULL, pixel_ratio = 1, sdf = FALSE, stretch_x = NULL, stretch_y = NULL )
add_image( map, id, url, content = NULL, pixel_ratio = 1, sdf = FALSE, stretch_x = NULL, stretch_y = NULL )
map |
A map object created by the |
id |
A string specifying the ID of the image. |
url |
A string specifying the URL of the image to be loaded or a path to a local image file. Must be PNG or JPEG format. |
content |
A vector of four numbers |
pixel_ratio |
A number specifying the ratio of pixels in the image to physical pixels on the screen. |
sdf |
A logical value indicating whether the image should be interpreted as an SDF image. |
stretch_x |
A list of number pairs defining the part(s) of the image that can be stretched horizontally. |
stretch_y |
A list of number pairs defining the part(s) of the image that can be stretched vertically. |
The modified map object with the image added.
## Not run: library(mapgl) # Path to your local image file OR a URL to a remote image file # that is not blocked by CORS restrictions image_path <- "/path/to/your/image.png" pts <- tigris::landmarks("DE")[1:100, ] maplibre(bounds = pts) |> add_image("local_icon", image_path) |> add_symbol_layer( id = "local_icons", source = pts, icon_image = "local_icon", icon_size = 0.5, icon_allow_overlap = TRUE ) ## End(Not run)
## Not run: library(mapgl) # Path to your local image file OR a URL to a remote image file # that is not blocked by CORS restrictions image_path <- "/path/to/your/image.png" pts <- tigris::landmarks("DE")[1:100, ] maplibre(bounds = pts) |> add_image("local_icon", image_path) |> add_symbol_layer( id = "local_icons", source = pts, icon_image = "local_icon", icon_size = 0.5, icon_allow_overlap = TRUE ) ## End(Not run)
Add an image source to a Mapbox GL or Maplibre GL map
add_image_source( map, id, url = NULL, data = NULL, coordinates = NULL, colors = NULL )
add_image_source( map, id, url = NULL, data = NULL, coordinates = NULL, colors = NULL )
map |
A map object created by the |
id |
A unique ID for the source. |
url |
A URL pointing to the image source. |
data |
A |
coordinates |
A list of coordinates specifying the image corners in clockwise order: top left, top right, bottom right, bottom left. For |
colors |
A vector of colors to use for the raster image. |
The modified map object with the new source added.
In many cases, you will use add_layer()
internal to other layer-specific functions in mapgl. Advanced users will want to use add_layer()
for more fine-grained control over the appearance of their layers.
add_layer( map, id, type = "fill", source, source_layer = NULL, paint = list(), layout = list(), slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
add_layer( map, id, type = "fill", source, source_layer = NULL, paint = list(), layout = list(), slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
type |
The type of the layer (e.g., "fill", "line", "circle"). |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
paint |
A list of paint properties for the layer. |
layout |
A list of layout properties for the layer. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
The modified map object with the new layer added.
## Not run: # Load necessary libraries library(mapgl) library(tigris) # Load geojson data for North Carolina tracts nc_tracts <- tracts(state = "NC", cb = TRUE) # Create a Mapbox GL map map <- mapboxgl( style = mapbox_style("light"), center = c(-79.0193, 35.7596), zoom = 7 ) # Add a source and fill layer for North Carolina tracts map %>% add_source( id = "nc-tracts", data = nc_tracts ) %>% add_layer( id = "nc-layer", type = "fill", source = "nc-tracts", paint = list( "fill-color" = "#888888", "fill-opacity" = 0.4 ) ) ## End(Not run)
## Not run: # Load necessary libraries library(mapgl) library(tigris) # Load geojson data for North Carolina tracts nc_tracts <- tracts(state = "NC", cb = TRUE) # Create a Mapbox GL map map <- mapboxgl( style = mapbox_style("light"), center = c(-79.0193, 35.7596), zoom = 7 ) # Add a source and fill layer for North Carolina tracts map %>% add_source( id = "nc-tracts", data = nc_tracts ) %>% add_layer( id = "nc-layer", type = "fill", source = "nc-tracts", paint = list( "fill-color" = "#888888", "fill-opacity" = 0.4 ) ) ## End(Not run)
Add a layers control to the map
add_layers_control( map, position = "top-left", layers = NULL, collapsible = TRUE, use_icon = TRUE, background_color = NULL, active_color = NULL, hover_color = NULL, active_text_color = NULL, inactive_text_color = NULL )
add_layers_control( map, position = "top-left", layers = NULL, collapsible = TRUE, use_icon = TRUE, background_color = NULL, active_color = NULL, hover_color = NULL, active_text_color = NULL, inactive_text_color = NULL )
map |
A map object. |
position |
The position of the control on the map (one of "top-left", "top-right", "bottom-left", "bottom-right"). |
layers |
A vector of layer IDs to be included in the control. If NULL, all layers will be included. |
collapsible |
Whether the control should be collapsible. |
use_icon |
Whether to use a stacked layers icon instead of the "Layers" text when collapsed. Only applies when collapsible = TRUE. |
background_color |
The background color for the layers control; this will be the color used for inactive layer items. |
active_color |
The background color for active layer items. |
hover_color |
The background color for layer items when hovered. |
active_text_color |
The text color for active layer items. |
inactive_text_color |
The text color for inactive layer items. |
The modified map object with the layers control added.
## Not run: library(tigris) options(tigris_use_cache = TRUE) rds <- roads("TX", "Tarrant") tr <- tracts("TX", "Tarrant", cb = TRUE) maplibre() |> fit_bounds(rds) |> add_fill_layer( id = "Census tracts", source = tr, fill_color = "purple", fill_opacity = 0.6 ) |> add_line_layer( "Local roads", source = rds, line_color = "pink" ) |> add_layers_control( position = "top-left", background_color = "#ffffff", active_color = "#4a90e2" ) ## End(Not run)
## Not run: library(tigris) options(tigris_use_cache = TRUE) rds <- roads("TX", "Tarrant") tr <- tracts("TX", "Tarrant", cb = TRUE) maplibre() |> fit_bounds(rds) |> add_fill_layer( id = "Census tracts", source = tr, fill_color = "purple", fill_opacity = 0.6 ) |> add_line_layer( "Local roads", source = rds, line_color = "pink" ) |> add_layers_control( position = "top-left", background_color = "#ffffff", active_color = "#4a90e2" ) ## End(Not run)
Add a legend to a Mapbox GL map
add_legend( map, legend_title, values, colors, type = c("continuous", "categorical"), circular_patches = FALSE, position = "top-left", sizes = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
add_legend( map, legend_title, values, colors, type = c("continuous", "categorical"), circular_patches = FALSE, position = "top-left", sizes = NULL, add = FALSE, width = NULL, layer_id = NULL, margin_top = NULL, margin_right = NULL, margin_bottom = NULL, margin_left = NULL )
map |
A map object created by the |
legend_title |
The title of the legend. |
values |
The values being represented on the map (either a vector of categories or a vector of stops). |
colors |
The corresponding colors for the values (either a vector of colors, a single color, or an interpolate function). |
type |
One of "continuous" or "categorical". |
circular_patches |
Logical, whether to use circular patches in the legend (only for categorical legends). |
position |
The position of the legend on the map (one of "top-left", "bottom-left", "top-right", "bottom-right"). |
sizes |
An optional numeric vector of sizes for the legend patches, or a single numeric value (only for categorical legends). |
add |
Logical, whether to add this legend to existing legends (TRUE) or replace existing legends (FALSE). Default is FALSE. |
width |
The width of the legend. Can be specified in pixels (e.g., "250px") or as "auto". Default is NULL, which uses the built-in default. |
layer_id |
The ID of the layer that this legend is associated with. If provided, the legend will be shown/hidden when the layer visibility is toggled. |
margin_top |
Custom top margin in pixels, allowing for fine control over legend positioning. Default is NULL (uses standard positioning). |
margin_right |
Custom right margin in pixels. Default is NULL. |
margin_bottom |
Custom bottom margin in pixels. Default is NULL. |
margin_left |
Custom left margin in pixels. Default is NULL. |
The updated map object with the legend added.
Add a line layer to a map
add_line_layer( map, id, source, source_layer = NULL, line_blur = NULL, line_cap = NULL, line_color = NULL, line_dasharray = NULL, line_emissive_strength = NULL, line_gap_width = NULL, line_gradient = NULL, line_join = NULL, line_miter_limit = NULL, line_occlusion_opacity = NULL, line_offset = NULL, line_opacity = NULL, line_pattern = NULL, line_round_limit = NULL, line_sort_key = NULL, line_translate = NULL, line_translate_anchor = "map", line_trim_color = NULL, line_trim_fade_range = NULL, line_trim_offset = NULL, line_width = NULL, line_z_offset = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
add_line_layer( map, id, source, source_layer = NULL, line_blur = NULL, line_cap = NULL, line_color = NULL, line_dasharray = NULL, line_emissive_strength = NULL, line_gap_width = NULL, line_gradient = NULL, line_join = NULL, line_miter_limit = NULL, line_occlusion_opacity = NULL, line_offset = NULL, line_opacity = NULL, line_pattern = NULL, line_round_limit = NULL, line_sort_key = NULL, line_translate = NULL, line_translate_anchor = "map", line_trim_color = NULL, line_trim_fade_range = NULL, line_trim_offset = NULL, line_width = NULL, line_z_offset = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be
converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
line_blur |
Amount to blur the line, in pixels. |
line_cap |
The display of line endings. One of "butt", "round", "square". |
line_color |
The color with which the line will be drawn. |
line_dasharray |
Specifies the lengths of the alternating dashes and gaps that form the dash pattern. |
line_emissive_strength |
Controls the intensity of light emitted on the source features. |
line_gap_width |
Draws a line casing outside of a line's actual path. Value indicates the width of the inner gap. |
line_gradient |
A gradient used to color a line feature at various distances along its length. |
line_join |
The display of lines when joining. |
line_miter_limit |
Used to automatically convert miter joins to bevel joins for sharp angles. |
line_occlusion_opacity |
Opacity multiplier of the line part that is occluded by 3D objects. |
line_offset |
The line's offset. |
line_opacity |
The opacity at which the line will be drawn. |
line_pattern |
Name of image in sprite to use for drawing image lines. |
line_round_limit |
Used to automatically convert round joins to miter joins for shallow angles. |
line_sort_key |
Sorts features in ascending order based on this value. |
line_translate |
The geometry's offset. Values are |
line_translate_anchor |
Controls the frame of reference for |
line_trim_color |
The color to be used for rendering the trimmed line section. |
line_trim_fade_range |
The fade range for the trim-start and trim-end points. |
line_trim_offset |
The line part between |
line_width |
Stroke thickness. |
line_z_offset |
Vertical offset from ground, in meters. |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels) |
filter |
An optional filter expression to subset features in the layer. |
The modified map object with the new line layer added.
## Not run: library(mapgl) library(tigris) loving_roads <- roads("TX", "Loving") maplibre(style = maptiler_style("backdrop")) |> fit_bounds(loving_roads) |> add_line_layer( id = "tracks", source = loving_roads, line_color = "navy", line_opacity = 0.7 ) ## End(Not run)
## Not run: library(mapgl) library(tigris) loving_roads <- roads("TX", "Loving") maplibre(style = maptiler_style("backdrop")) |> fit_bounds(loving_roads) |> add_line_layer( id = "tracks", source = loving_roads, line_color = "navy", line_opacity = 0.7 ) ## End(Not run)
Add markers to a Mapbox GL or Maplibre GL map
add_markers( map, data, color = "red", rotation = 0, popup = NULL, marker_id = NULL, draggable = FALSE, ... )
add_markers( map, data, color = "red", rotation = 0, popup = NULL, marker_id = NULL, draggable = FALSE, ... )
map |
A map object created by the |
data |
A length-2 numeric vector of coordinates, a list of length-2 numeric vectors, or an |
color |
The color of the marker (default is "red"). |
rotation |
The rotation of the marker (default is 0). |
popup |
A column name for popups (if data is an |
marker_id |
A unique ID for the marker. For lists, names will be inherited from the list names. For |
draggable |
A boolean indicating if the marker should be draggable (default is FALSE). |
... |
Additional options passed to the marker. |
The modified map object with the markers added.
## Not run: library(mapgl) library(sf) # Create a map object map <- mapboxgl( style = mapbox_style("streets"), center = c(-74.006, 40.7128), zoom = 10 ) # Add a single draggable marker with an ID map <- add_markers( map, c(-74.006, 40.7128), color = "blue", rotation = 45, popup = "A marker", draggable = TRUE, marker_id = "marker1" ) # Add multiple markers from a named list of coordinates coords_list <- list(marker2 = c(-74.006, 40.7128), marker3 = c(-73.935242, 40.730610)) map <- add_markers( map, coords_list, color = "green", popup = "Multiple markers", draggable = TRUE ) # Create an sf POINT object points_sf <- st_as_sf(data.frame( id = c("marker4", "marker5"), lon = c(-74.006, -73.935242), lat = c(40.7128, 40.730610) ), coords = c("lon", "lat"), crs = 4326) points_sf$popup <- c("Point 1", "Point 2") # Add multiple markers from an sf object with IDs from a column map <- add_markers( map, points_sf, color = "red", popup = "popup", draggable = TRUE, marker_id = "id" ) ## End(Not run)
## Not run: library(mapgl) library(sf) # Create a map object map <- mapboxgl( style = mapbox_style("streets"), center = c(-74.006, 40.7128), zoom = 10 ) # Add a single draggable marker with an ID map <- add_markers( map, c(-74.006, 40.7128), color = "blue", rotation = 45, popup = "A marker", draggable = TRUE, marker_id = "marker1" ) # Add multiple markers from a named list of coordinates coords_list <- list(marker2 = c(-74.006, 40.7128), marker3 = c(-73.935242, 40.730610)) map <- add_markers( map, coords_list, color = "green", popup = "Multiple markers", draggable = TRUE ) # Create an sf POINT object points_sf <- st_as_sf(data.frame( id = c("marker4", "marker5"), lon = c(-74.006, -73.935242), lat = c(40.7128, 40.730610) ), coords = c("lon", "lat"), crs = 4326) points_sf$popup <- c("Point 1", "Point 2") # Add multiple markers from an sf object with IDs from a column map <- add_markers( map, points_sf, color = "red", popup = "popup", draggable = TRUE, marker_id = "id" ) ## End(Not run)
Add a raster DEM source to a Mapbox GL or Maplibre GL map
add_raster_dem_source(map, id, url, tileSize = 512, maxzoom = NULL)
add_raster_dem_source(map, id, url, tileSize = 512, maxzoom = NULL)
map |
A map object created by the |
id |
A unique ID for the source. |
url |
A URL pointing to the raster DEM source. |
tileSize |
The size of the raster tiles. |
maxzoom |
The maximum zoom level for the raster tiles. |
The modified map object with the new source added.
Add a raster layer to a Mapbox GL map
add_raster_layer( map, id, source, source_layer = NULL, raster_brightness_max = NULL, raster_brightness_min = NULL, raster_contrast = NULL, raster_fade_duration = NULL, raster_hue_rotate = NULL, raster_opacity = NULL, raster_resampling = NULL, raster_saturation = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, before_id = NULL )
add_raster_layer( map, id, source, source_layer = NULL, raster_brightness_max = NULL, raster_brightness_min = NULL, raster_contrast = NULL, raster_fade_duration = NULL, raster_hue_rotate = NULL, raster_opacity = NULL, raster_resampling = NULL, raster_saturation = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, before_id = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source. |
source_layer |
The source layer (for vector sources). |
raster_brightness_max |
The maximum brightness of the image. |
raster_brightness_min |
The minimum brightness of the image. |
raster_contrast |
Increase or reduce the brightness of the image. |
raster_fade_duration |
The duration of the fade-in/fade-out effect. |
raster_hue_rotate |
Rotates hues around the color wheel. |
raster_opacity |
The opacity at which the raster will be drawn. |
raster_resampling |
The resampling/interpolation method to use for overscaling. |
raster_saturation |
Increase or reduce the saturation of the image. |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
The modified map object with the new raster layer added.
## Not run: mapboxgl( style = mapbox_style("dark"), zoom = 5, center = c(-75.789, 41.874) ) |> add_image_source( id = "radar", url = "https://docs.mapbox.com/mapbox-gl-js/assets/radar.gif", coordinates = list( c(-80.425, 46.437), c(-71.516, 46.437), c(-71.516, 37.936), c(-80.425, 37.936) ) ) |> add_raster_layer( id = "radar-layer", source = "radar", raster_fade_duration = 0 ) ## End(Not run)
## Not run: mapboxgl( style = mapbox_style("dark"), zoom = 5, center = c(-75.789, 41.874) ) |> add_image_source( id = "radar", url = "https://docs.mapbox.com/mapbox-gl-js/assets/radar.gif", coordinates = list( c(-80.425, 46.437), c(-71.516, 46.437), c(-71.516, 37.936), c(-80.425, 37.936) ) ) |> add_raster_layer( id = "radar-layer", source = "radar", raster_fade_duration = 0 ) ## End(Not run)
Add a raster tile source to a Mapbox GL or Maplibre GL map
add_raster_source( map, id, url = NULL, tiles = NULL, tileSize = 256, maxzoom = 22 )
add_raster_source( map, id, url = NULL, tiles = NULL, tileSize = 256, maxzoom = 22 )
map |
A map object created by the |
id |
A unique ID for the source. |
url |
A URL pointing to the raster tile source. (optional) |
tiles |
A vector of tile URLs for the raster source. (optional) |
tileSize |
The size of the raster tiles. |
maxzoom |
The maximum zoom level for the raster tiles. |
The modified map object with the new source added.
This function adds a reset control to a Mapbox GL or MapLibre GL map. The reset control allows users to return to the original zoom level and center.
add_reset_control(map, position = "top-right", animate = TRUE, duration = NULL)
add_reset_control(map, position = "top-right", animate = TRUE, duration = NULL)
map |
A map object created by the |
position |
The position of the control. Can be one of "top-left", "top-right", "bottom-left", or "bottom-right". Default is "top-right". |
animate |
Whether or not to animate the transition to the original map view; defaults to |
duration |
The length of the transition from the current view to the original view, specified in milliseconds. This argument only works with |
The modified map object with the reset control added.
## Not run: library(mapgl) mapboxgl() |> add_reset_control(position = "top-left") ## End(Not run)
## Not run: library(mapgl) mapboxgl() |> add_reset_control(position = "top-left") ## End(Not run)
This function adds a scale control to a Mapbox GL or Maplibre GL map.
add_scale_control( map, position = "bottom-left", unit = "metric", max_width = 100 )
add_scale_control( map, position = "bottom-left", unit = "metric", max_width = 100 )
map |
A map object created by the |
position |
The position of the control. Can be one of "top-left", "top-right", "bottom-left", or "bottom-right". Default is "bottom-left". |
unit |
The unit of the scale. Can be either "imperial", "metric", or "nautical". Default is "metric". |
max_width |
The maximum length of the scale control in pixels. Default is 100. |
The modified map object with the scale control added.
## Not run: library(mapgl) mapboxgl() |> add_scale_control(position = "bottom-right", unit = "imperial") ## End(Not run)
## Not run: library(mapgl) mapboxgl() |> add_scale_control(position = "bottom-right", unit = "imperial") ## End(Not run)
Add a GeoJSON or sf source to a Mapbox GL or Maplibre GL map
add_source(map, id, data, ...)
add_source(map, id, data, ...)
map |
A map object created by the |
id |
A unique ID for the source. |
data |
An sf object or a URL pointing to a remote GeoJSON file. |
... |
Additional arguments to be passed to the JavaScript addSource method. |
The modified map object with the new source added.
Add a symbol layer to a map
add_symbol_layer( map, id, source, source_layer = NULL, icon_allow_overlap = NULL, icon_anchor = NULL, icon_color = NULL, icon_color_brightness_max = NULL, icon_color_brightness_min = NULL, icon_color_contrast = NULL, icon_color_saturation = NULL, icon_emissive_strength = NULL, icon_halo_blur = NULL, icon_halo_color = NULL, icon_halo_width = NULL, icon_ignore_placement = NULL, icon_image = NULL, icon_image_cross_fade = NULL, icon_keep_upright = NULL, icon_offset = NULL, icon_opacity = NULL, icon_optional = NULL, icon_padding = NULL, icon_pitch_alignment = NULL, icon_rotate = NULL, icon_rotation_alignment = NULL, icon_size = NULL, icon_text_fit = NULL, icon_text_fit_padding = NULL, icon_translate = NULL, icon_translate_anchor = NULL, symbol_avoid_edges = NULL, symbol_placement = NULL, symbol_sort_key = NULL, symbol_spacing = NULL, symbol_z_elevate = NULL, symbol_z_offset = NULL, symbol_z_order = NULL, text_allow_overlap = NULL, text_anchor = NULL, text_color = "black", text_emissive_strength = NULL, text_field = NULL, text_font = NULL, text_halo_blur = NULL, text_halo_color = NULL, text_halo_width = NULL, text_ignore_placement = NULL, text_justify = NULL, text_keep_upright = NULL, text_letter_spacing = NULL, text_line_height = NULL, text_max_angle = NULL, text_max_width = NULL, text_offset = NULL, text_opacity = NULL, text_optional = NULL, text_padding = NULL, text_pitch_alignment = NULL, text_radial_offset = NULL, text_rotate = NULL, text_rotation_alignment = NULL, text_size = NULL, text_transform = NULL, text_translate = NULL, text_translate_anchor = NULL, text_variable_anchor = NULL, text_writing_mode = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL, cluster_options = NULL )
add_symbol_layer( map, id, source, source_layer = NULL, icon_allow_overlap = NULL, icon_anchor = NULL, icon_color = NULL, icon_color_brightness_max = NULL, icon_color_brightness_min = NULL, icon_color_contrast = NULL, icon_color_saturation = NULL, icon_emissive_strength = NULL, icon_halo_blur = NULL, icon_halo_color = NULL, icon_halo_width = NULL, icon_ignore_placement = NULL, icon_image = NULL, icon_image_cross_fade = NULL, icon_keep_upright = NULL, icon_offset = NULL, icon_opacity = NULL, icon_optional = NULL, icon_padding = NULL, icon_pitch_alignment = NULL, icon_rotate = NULL, icon_rotation_alignment = NULL, icon_size = NULL, icon_text_fit = NULL, icon_text_fit_padding = NULL, icon_translate = NULL, icon_translate_anchor = NULL, symbol_avoid_edges = NULL, symbol_placement = NULL, symbol_sort_key = NULL, symbol_spacing = NULL, symbol_z_elevate = NULL, symbol_z_offset = NULL, symbol_z_order = NULL, text_allow_overlap = NULL, text_anchor = NULL, text_color = "black", text_emissive_strength = NULL, text_field = NULL, text_font = NULL, text_halo_blur = NULL, text_halo_color = NULL, text_halo_width = NULL, text_ignore_placement = NULL, text_justify = NULL, text_keep_upright = NULL, text_letter_spacing = NULL, text_line_height = NULL, text_max_angle = NULL, text_max_width = NULL, text_offset = NULL, text_opacity = NULL, text_optional = NULL, text_padding = NULL, text_pitch_alignment = NULL, text_radial_offset = NULL, text_rotate = NULL, text_rotation_alignment = NULL, text_size = NULL, text_transform = NULL, text_translate = NULL, text_translate_anchor = NULL, text_variable_anchor = NULL, text_writing_mode = NULL, visibility = "visible", slot = NULL, min_zoom = NULL, max_zoom = NULL, popup = NULL, tooltip = NULL, hover_options = NULL, before_id = NULL, filter = NULL, cluster_options = NULL )
map |
A map object created by the |
id |
A unique ID for the layer. |
source |
The ID of the source, alternatively an sf object (which will be converted to a GeoJSON source) or a named list that specifies |
source_layer |
The source layer (for vector sources). |
icon_allow_overlap |
If TRUE, the icon will be visible even if it collides with other previously drawn symbols. |
icon_anchor |
Part of the icon placed closest to the anchor. |
icon_color |
The color of the icon. This is not supported for many Mapbox icons; read more at https://docs.mapbox.com/help/troubleshooting/using-recolorable-images-in-mapbox-maps/. |
icon_color_brightness_max |
The maximum brightness of the icon color. |
icon_color_brightness_min |
The minimum brightness of the icon color. |
icon_color_contrast |
The contrast of the icon color. |
icon_color_saturation |
The saturation of the icon color. |
icon_emissive_strength |
The strength of the icon's emissive color. |
icon_halo_blur |
The blur applied to the icon's halo. |
icon_halo_color |
The color of the icon's halo. |
icon_halo_width |
The width of the icon's halo. |
icon_ignore_placement |
If TRUE, the icon will be visible even if it collides with other symbols. |
icon_image |
Name of image in sprite to use for drawing an image background.
To use values in a column of your input dataset, use |
icon_image_cross_fade |
The cross-fade parameter for the icon image. |
icon_keep_upright |
If TRUE, the icon will be kept upright. |
icon_offset |
Offset distance of icon. |
icon_opacity |
The opacity at which the icon will be drawn. |
icon_optional |
If TRUE, the icon will be optional. |
icon_padding |
Padding around the icon. |
icon_pitch_alignment |
Alignment of the icon with respect to the pitch of the map. |
icon_rotate |
Rotates the icon clockwise. |
icon_rotation_alignment |
Alignment of the icon with respect to the map. |
icon_size |
The size of the icon, specified relative to the original size of the image. For example, a value of 5 would make the icon 5 times larger than the original size, whereas a value of 0.5 would make the icon half the size of the original. |
icon_text_fit |
Scales the text to fit the icon. |
icon_text_fit_padding |
Padding for text fitting the icon. |
icon_translate |
The offset distance of the icon. |
icon_translate_anchor |
Controls the frame of reference for |
symbol_avoid_edges |
If TRUE, the symbol will be avoided when near the edges. |
symbol_placement |
Placement of the symbol on the map. |
symbol_sort_key |
Sorts features in ascending order based on this value. |
symbol_spacing |
Spacing between symbols. |
symbol_z_elevate |
If |
symbol_z_offset |
The elevation of the symbol, in meters. Use |
symbol_z_order |
Orders the symbol z-axis. |
text_allow_overlap |
If TRUE, the text will be visible even if it collides with other previously drawn symbols. |
text_anchor |
Part of the text placed closest to the anchor. |
text_color |
The color of the text. |
text_emissive_strength |
The strength of the text's emissive color. |
text_field |
Value to use for a text label. |
text_font |
Font stack to use for displaying text. |
text_halo_blur |
The blur applied to the text's halo. |
text_halo_color |
The color of the text's halo. |
text_halo_width |
The width of the text's halo. |
text_ignore_placement |
If TRUE, the text will be visible even if it collides with other symbols. |
text_justify |
The justification of the text. |
text_keep_upright |
If TRUE, the text will be kept upright. |
text_letter_spacing |
Spacing between text letters. |
text_line_height |
Height of the text lines. |
text_max_angle |
Maximum angle of the text. |
text_max_width |
Maximum width of the text. |
text_offset |
Offset distance of text. |
text_opacity |
The opacity at which the text will be drawn. |
text_optional |
If TRUE, the text will be optional. |
text_padding |
Padding around the text. |
text_pitch_alignment |
Alignment of the text with respect to the pitch of the map. |
text_radial_offset |
Radial offset of the text. |
text_rotate |
Rotates the text clockwise. |
text_rotation_alignment |
Alignment of the text with respect to the map. |
text_size |
The size of the text. |
text_transform |
Transform applied to the text. |
text_translate |
The offset distance of the text. |
text_translate_anchor |
Controls the frame of reference for |
text_variable_anchor |
Variable anchor for the text. |
text_writing_mode |
Writing mode for the text. |
visibility |
Whether this layer is displayed. |
slot |
An optional slot for layer order. |
min_zoom |
The minimum zoom level for the layer. |
max_zoom |
The maximum zoom level for the layer. |
popup |
A column name containing information to display in a popup on click. Columns containing HTML will be parsed. |
tooltip |
A column name containing information to display in a tooltip on hover. Columns containing HTML will be parsed. |
hover_options |
A named list of options for highlighting features in the layer on hover. Not all elements of SVG icons can be styled. |
before_id |
The name of the layer that this layer appears "before", allowing you to insert layers below other layers in your basemap (e.g. labels). |
filter |
An optional filter expression to subset features in the layer. |
cluster_options |
A list of options for clustering symbols, created by the |
The modified map object with the new symbol layer added.
## Not run: library(mapgl) library(sf) library(dplyr) # Set seed for reproducibility set.seed(1234) # Define the bounding box for Washington DC (approximately) bbox <- st_bbox( c( xmin = -77.119759, ymin = 38.791645, xmax = -76.909393, ymax = 38.995548 ), crs = st_crs(4326) ) # Generate 30 random points within the bounding box random_points <- st_as_sf( data.frame( id = 1:30, lon = runif(30, bbox["xmin"], bbox["xmax"]), lat = runif(30, bbox["ymin"], bbox["ymax"]) ), coords = c("lon", "lat"), crs = 4326 ) # Assign random icons icons <- c("music", "bar", "theatre", "bicycle") random_points <- random_points |> mutate(icon = sample(icons, n(), replace = TRUE)) # Map with icons mapboxgl(style = mapbox_style("light")) |> fit_bounds(random_points, animate = FALSE) |> add_symbol_layer( id = "points-of-interest", source = random_points, icon_image = c("get", "icon"), icon_allow_overlap = TRUE, tooltip = "icon" ) ## End(Not run)
## Not run: library(mapgl) library(sf) library(dplyr) # Set seed for reproducibility set.seed(1234) # Define the bounding box for Washington DC (approximately) bbox <- st_bbox( c( xmin = -77.119759, ymin = 38.791645, xmax = -76.909393, ymax = 38.995548 ), crs = st_crs(4326) ) # Generate 30 random points within the bounding box random_points <- st_as_sf( data.frame( id = 1:30, lon = runif(30, bbox["xmin"], bbox["xmax"]), lat = runif(30, bbox["ymin"], bbox["ymax"]) ), coords = c("lon", "lat"), crs = 4326 ) # Assign random icons icons <- c("music", "bar", "theatre", "bicycle") random_points <- random_points |> mutate(icon = sample(icons, n(), replace = TRUE)) # Map with icons mapboxgl(style = mapbox_style("light")) |> fit_bounds(random_points, animate = FALSE) |> add_symbol_layer( id = "points-of-interest", source = random_points, icon_image = c("get", "icon"), icon_allow_overlap = TRUE, tooltip = "icon" ) ## End(Not run)
Add a vector tile source to a Mapbox GL or Maplibre GL map
add_vector_source(map, id, url)
add_vector_source(map, id, url)
map |
A map object created by the |
id |
A unique ID for the source. |
url |
A URL pointing to the vector tile source. |
The modified map object with the new source added.
Add a video source to a Mapbox GL or Maplibre GL map
add_video_source(map, id, urls, coordinates)
add_video_source(map, id, urls, coordinates)
map |
A map object created by the |
id |
A unique ID for the source. |
urls |
A vector of URLs pointing to the video sources. |
coordinates |
A list of coordinates specifying the video corners in clockwise order: top left, top right, bottom right, bottom left. |
The modified map object with the new source added.
Get CARTO Style URL
carto_style(style_name)
carto_style(style_name)
style_name |
The name of the style (e.g., "voyager", "positron", "dark-matter"). |
The style URL corresponding to the given style name.
Clear all controls from a Mapbox GL or Maplibre GL map in a Shiny app
clear_controls(map)
clear_controls(map)
map |
A map object created by the |
The modified map object with all controls removed.
This function allows a layer to be removed from an existing Mapbox GL map using a proxy object.
clear_layer(proxy, layer_id)
clear_layer(proxy, layer_id)
proxy |
A proxy object created by |
layer_id |
The ID of the layer to be removed. |
The updated proxy object.
Clear legend from a map in a proxy session
clear_legend(map)
clear_legend(map)
map |
A map object created by the |
The updated map object with the legend cleared.
Clear markers from a map in a Shiny session
clear_markers(map)
clear_markers(map)
map |
A map object created by the |
The modified map object with the markers cleared.
This function creates a list of options for clustering circle layers.
cluster_options( max_zoom = 14, cluster_radius = 50, color_stops = c("#51bbd6", "#f1f075", "#f28cb1"), radius_stops = c(20, 30, 40), count_stops = c(0, 100, 750), circle_blur = NULL, circle_opacity = NULL, circle_stroke_color = NULL, circle_stroke_opacity = NULL, circle_stroke_width = NULL, text_color = "black" )
cluster_options( max_zoom = 14, cluster_radius = 50, color_stops = c("#51bbd6", "#f1f075", "#f28cb1"), radius_stops = c(20, 30, 40), count_stops = c(0, 100, 750), circle_blur = NULL, circle_opacity = NULL, circle_stroke_color = NULL, circle_stroke_opacity = NULL, circle_stroke_width = NULL, text_color = "black" )
max_zoom |
The maximum zoom level at which to cluster points. |
cluster_radius |
The radius of each cluster when clustering points. |
color_stops |
A vector of colors for the circle color step expression. |
radius_stops |
A vector of radii for the circle radius step expression. |
count_stops |
A vector of point counts for both color and radius step expressions. |
circle_blur |
Amount to blur the circle. |
circle_opacity |
The opacity of the circle. |
circle_stroke_color |
The color of the circle's stroke. |
circle_stroke_opacity |
The opacity of the circle's stroke. |
circle_stroke_width |
The width of the circle's stroke. |
text_color |
The color to use for labels on the cluster circles. |
A list of cluster options.
cluster_options( max_zoom = 14, cluster_radius = 50, color_stops = c("#51bbd6", "#f1f075", "#f28cb1"), radius_stops = c(20, 30, 40), count_stops = c(0, 100, 750), circle_blur = 1, circle_opacity = 0.8, circle_stroke_color = "#ffffff", circle_stroke_width = 2 )
cluster_options( max_zoom = 14, cluster_radius = 50, color_stops = c("#51bbd6", "#f1f075", "#f28cb1"), radius_stops = c(20, 30, 40), count_stops = c(0, 100, 750), circle_blur = 1, circle_opacity = 0.8, circle_stroke_color = "#ffffff", circle_stroke_width = 2 )
This function creates a comparison view between two Mapbox GL or Maplibre GL maps, allowing users to either swipe between the two maps or view them side-by-side with synchronized navigation.
compare( map1, map2, width = "100%", height = NULL, elementId = NULL, mousemove = FALSE, orientation = "vertical", mode = "swipe" )
compare( map1, map2, width = "100%", height = NULL, elementId = NULL, mousemove = FALSE, orientation = "vertical", mode = "swipe" )
map1 |
A |
map2 |
A |
width |
Width of the map container. |
height |
Height of the map container. |
elementId |
An optional string specifying the ID of the container for the comparison. If NULL, a unique ID will be generated. |
mousemove |
A logical value indicating whether to enable swiping during cursor movement (rather than only when clicked). Only applicable when |
orientation |
A string specifying the orientation of the swiper or the side-by-side layout, either "horizontal" or "vertical". |
mode |
A string specifying the comparison mode: "swipe" (default) for a swipeable comparison with a slider, or "sync" for synchronized maps displayed next to each other. |
The compare()
function supports two modes:
mode="swipe"
(default) - Creates a swipeable interface with a slider to reveal portions of each map
mode="sync"
- Places the maps next to each other with synchronized navigation
In both modes, navigation (panning, zooming, rotating, tilting) is synchronized between the maps.
The compare widget can be used in Shiny applications with the following functions:
mapboxglCompareOutput()
/ renderMapboxglCompare()
- For Mapbox GL comparisons
maplibreCompareOutput()
/ renderMaplibreCompare()
- For Maplibre GL comparisons
mapboxgl_compare_proxy()
/ maplibre_compare_proxy()
- For updating maps in a compare widget
After creating a compare widget in a Shiny app, you can use the proxy functions to update either the "before"
(left/top) or "after" (right/bottom) map. The proxy objects work with all the regular map update functions like set_style()
,
set_paint_property()
, etc.
To get a proxy that targets a specific map in the comparison:
# Access the left/top map left_proxy <- maplibre_compare_proxy("compare_id", map_side = "before") # Access the right/bottom map right_proxy <- maplibre_compare_proxy("compare_id", map_side = "after")
The compare widget also provides Shiny input values for view state and clicks. For a compare widget with ID "mycompare", you'll have:
input$mycompare_before_view
- View state (center, zoom, bearing, pitch) of the left/top map
input$mycompare_after_view
- View state of the right/bottom map
input$mycompare_before_click
- Click events on the left/top map
input$mycompare_after_click
- Click events on the right/bottom map
A comparison widget.
## Not run: library(mapgl) m1 <- mapboxgl(style = mapbox_style("light")) m2 <- mapboxgl(style = mapbox_style("dark")) # Default swipe mode compare(m1, m2) # Synchronized side-by-side mode compare(m1, m2, mode = "sync") # Shiny example library(shiny) ui <- fluidPage( maplibreCompareOutput("comparison") ) server <- function(input, output, session) { output$comparison <- renderMaplibreCompare({ compare( maplibre(style = carto_style("positron")), maplibre(style = carto_style("dark-matter")), mode = "sync" ) }) # Update the right map observe({ right_proxy <- maplibre_compare_proxy("comparison", map_side = "after") set_style(right_proxy, carto_style("voyager")) }) } ## End(Not run)
## Not run: library(mapgl) m1 <- mapboxgl(style = mapbox_style("light")) m2 <- mapboxgl(style = mapbox_style("dark")) # Default swipe mode compare(m1, m2) # Synchronized side-by-side mode compare(m1, m2, mode = "sync") # Shiny example library(shiny) ui <- fluidPage( maplibreCompareOutput("comparison") ) server <- function(input, output, session) { output$comparison <- renderMaplibreCompare({ compare( maplibre(style = carto_style("positron")), maplibre(style = carto_style("dark-matter")), mode = "sync" ) }) # Update the right map observe({ right_proxy <- maplibre_compare_proxy("comparison", map_side = "after") set_style(right_proxy, carto_style("voyager")) }) } ## End(Not run)
Ease to a given view
ease_to(map, center, zoom = NULL, ...)
ease_to(map, center, zoom = NULL, ...)
map |
A map object created by the |
center |
A numeric vector of length 2 specifying the target center of the map (longitude, latitude). |
zoom |
The target zoom level. |
... |
Additional named arguments for easing to the view. |
The updated map object.
Fit the map to a bounding box
fit_bounds(map, bbox, animate = FALSE, ...)
fit_bounds(map, bbox, animate = FALSE, ...)
map |
A map object created by the |
bbox |
A bounding box specified as a numeric vector of length 4 (minLng, minLat, maxLng, maxLat), or an sf object from which a bounding box will be calculated. |
animate |
A logical value indicating whether to animate the transition to the new bounds. Defaults to FALSE. |
... |
Additional named arguments for fitting the bounds. |
The updated map object.
Fly to a given view
fly_to(map, center, zoom = NULL, ...)
fly_to(map, center, zoom = NULL, ...)
map |
A map object created by the |
center |
A numeric vector of length 2 specifying the target center of the map (longitude, latitude). |
zoom |
The target zoom level. |
... |
Additional named arguments for flying to the view. |
The updated map object.
This function returns a an expression to get a specified column from a dataset (or a property from a layer).
get_column(column)
get_column(column)
column |
The name of the column or property to get. |
A list representing the expression to get the column.
Get drawn features from the map
get_drawn_features(map)
get_drawn_features(map)
map |
A map object created by the |
An sf object containing the drawn features.
## Not run: # In a Shiny application library(shiny) library(mapgl) ui <- fluidPage( mapboxglOutput("map"), actionButton("get_features", "Get Drawn Features"), verbatimTextOutput("feature_output") ) server <- function(input, output, session) { output$map <- renderMapboxgl({ mapboxgl( style = mapbox_style("streets"), center = c(-74.50, 40), zoom = 9 ) |> add_draw_control() }) observeEvent(input$get_features, { drawn_features <- get_drawn_features(mapboxgl_proxy("map")) output$feature_output <- renderPrint({ print(drawn_features) }) }) } shinyApp(ui, server) ## End(Not run)
## Not run: # In a Shiny application library(shiny) library(mapgl) ui <- fluidPage( mapboxglOutput("map"), actionButton("get_features", "Get Drawn Features"), verbatimTextOutput("feature_output") ) server <- function(input, output, session) { output$map <- renderMapboxgl({ mapboxgl( style = mapbox_style("streets"), center = c(-74.50, 40), zoom = 9 ) |> add_draw_control() }) observeEvent(input$get_features, { drawn_features <- get_drawn_features(mapboxgl_proxy("map")) output$feature_output <- renderPrint({ print(drawn_features) }) }) } shinyApp(ui, server) ## End(Not run)
This function generates an interpolation expression that can be used to style your data.
interpolate( column = NULL, property = NULL, type = "linear", values, stops, na_color = NULL )
interpolate( column = NULL, property = NULL, type = "linear", values, stops, na_color = NULL )
column |
The name of the column to use for the interpolation. If specified, |
property |
The name of the property to use for the interpolation. If specified, |
type |
The interpolation type. Can be one of |
values |
A numeric vector of values at which stops occur. |
stops |
A vector of corresponding stops (colors, sizes, etc.) for the interpolation. |
na_color |
The color to use for missing values. Mapbox GL JS defaults to black if this is not supplied. |
A list representing the interpolation expression.
interpolate( column = "estimate", type = "linear", values = c(1000, 200000), stops = c("#eff3ff", "#08519c") )
interpolate( column = "estimate", type = "linear", values = c(1000, 200000), stops = c("#eff3ff", "#08519c") )
Jump to a given view
jump_to(map, center, zoom = NULL, ...)
jump_to(map, center, zoom = NULL, ...)
map |
A map object created by the |
center |
A numeric vector of length 2 specifying the target center of the map (longitude, latitude). |
zoom |
The target zoom level. |
... |
Additional named arguments for jumping to the view. |
The updated map object.
Get Mapbox Style URL
mapbox_style(style_name)
mapbox_style(style_name)
style_name |
The name of the style (e.g., "standard", "streets", "outdoors", etc.). |
The style URL corresponding to the given style name.
Initialize a Mapbox GL Map
mapboxgl( style = NULL, center = c(0, 0), zoom = 0, bearing = 0, pitch = 0, projection = "globe", parallels = NULL, access_token = NULL, bounds = NULL, width = "100%", height = NULL, ... )
mapboxgl( style = NULL, center = c(0, 0), zoom = 0, bearing = 0, pitch = 0, projection = "globe", parallels = NULL, access_token = NULL, bounds = NULL, width = "100%", height = NULL, ... )
style |
The Mapbox style to use. |
center |
A numeric vector of length 2 specifying the initial center of the map. |
zoom |
The initial zoom level of the map. |
bearing |
The initial bearing (rotation) of the map, in degrees. |
pitch |
The initial pitch (tilt) of the map, in degrees. |
projection |
The map projection to use (e.g., "mercator", "globe"). |
parallels |
A vector of two numbers representing the standard parellels of the projection. Only available when the projection is "albers" or "lambertConformalConic". |
access_token |
Your Mapbox access token. |
bounds |
An sf object or bounding box to fit the map to. |
width |
The width of the output htmlwidget. |
height |
The height of the output htmlwidget. |
... |
Additional named parameters to be passed to the Mapbox GL map. |
An HTML widget for a Mapbox map.
## Not run: mapboxgl(projection = "globe") ## End(Not run)
## Not run: mapboxgl(projection = "globe") ## End(Not run)
This function allows updates to be sent to an existing Mapbox GL Compare widget in a Shiny application.
mapboxgl_compare_proxy( compareId, session = shiny::getDefaultReactiveDomain(), map_side = "before" )
mapboxgl_compare_proxy( compareId, session = shiny::getDefaultReactiveDomain(), map_side = "before" )
compareId |
The ID of the compare output element. |
session |
The Shiny session object. |
map_side |
Which map side to target in the compare widget, either "before" or "after". |
A proxy object for the Mapbox GL Compare widget.
This function allows updates to be sent to an existing Mapbox GL map in a Shiny application without redrawing the entire map.
mapboxgl_proxy(mapId, session = shiny::getDefaultReactiveDomain())
mapboxgl_proxy(mapId, session = shiny::getDefaultReactiveDomain())
mapId |
The ID of the map output element. |
session |
The Shiny session object. |
A proxy object for the Mapbox GL map.
Create a Mapbox GL Compare output element for Shiny
mapboxglCompareOutput(outputId, width = "100%", height = "400px")
mapboxglCompareOutput(outputId, width = "100%", height = "400px")
outputId |
The output variable to read from |
width |
The width of the element |
height |
The height of the element |
A Mapbox GL Compare output element for use in a Shiny UI
Create a Mapbox GL output element for Shiny
mapboxglOutput(outputId, width = "100%", height = "400px")
mapboxglOutput(outputId, width = "100%", height = "400px")
outputId |
The output variable to read from |
width |
The width of the element |
height |
The height of the element |
A Mapbox GL output element for use in a Shiny UI
Initialize a Maplibre GL Map
maplibre( style = carto_style("voyager"), center = c(0, 0), zoom = 0, bearing = 0, pitch = 0, bounds = NULL, width = "100%", height = NULL, ... )
maplibre( style = carto_style("voyager"), center = c(0, 0), zoom = 0, bearing = 0, pitch = 0, bounds = NULL, width = "100%", height = NULL, ... )
style |
The style JSON to use. |
center |
A numeric vector of length 2 specifying the initial center of the map. |
zoom |
The initial zoom level of the map. |
bearing |
The initial bearing (rotation) of the map, in degrees. |
pitch |
The initial pitch (tilt) of the map, in degrees. |
bounds |
An sf object or bounding box to fit the map to. |
width |
The width of the output htmlwidget. |
height |
The height of the output htmlwidget. |
... |
Additional named parameters to be passed to the Mapbox GL map. |
An HTML widget for a Mapbox map.
## Not run: maplibre() ## End(Not run)
## Not run: maplibre() ## End(Not run)
This function allows updates to be sent to an existing Maplibre GL Compare widget in a Shiny application.
maplibre_compare_proxy( compareId, session = shiny::getDefaultReactiveDomain(), map_side = "before" )
maplibre_compare_proxy( compareId, session = shiny::getDefaultReactiveDomain(), map_side = "before" )
compareId |
The ID of the compare output element. |
session |
The Shiny session object. |
map_side |
Which map side to target in the compare widget, either "before" or "after". |
A proxy object for the Maplibre GL Compare widget.
This function allows updates to be sent to an existing Maplibre GL map in a Shiny application without redrawing the entire map.
maplibre_proxy(mapId, session = shiny::getDefaultReactiveDomain())
maplibre_proxy(mapId, session = shiny::getDefaultReactiveDomain())
mapId |
The ID of the map output element. |
session |
The Shiny session object. |
A proxy object for the Maplibre GL map.
Create a Maplibre GL Compare output element for Shiny
maplibreCompareOutput(outputId, width = "100%", height = "400px")
maplibreCompareOutput(outputId, width = "100%", height = "400px")
outputId |
The output variable to read from |
width |
The width of the element |
height |
The height of the element |
A Maplibre GL Compare output element for use in a Shiny UI
Create a Maplibre GL output element for Shiny
maplibreOutput(outputId, width = "100%", height = "400px")
maplibreOutput(outputId, width = "100%", height = "400px")
outputId |
The output variable to read from |
width |
The width of the element |
height |
The height of the element |
A Maplibre GL output element for use in a Shiny UI
Get MapTiler Style URL
maptiler_style(style_name, api_key = NULL)
maptiler_style(style_name, api_key = NULL)
style_name |
The name of the style (e.g., "basic", "streets", "toner", etc.). |
api_key |
Your MapTiler API key (required) |
The style URL corresponding to the given style name.
This function generates a match expression that can be used to style your data.
match_expr(column = NULL, property = NULL, values, stops, default = "#cccccc")
match_expr(column = NULL, property = NULL, values, stops, default = "#cccccc")
column |
The name of the column to use for the match expression. If specified, |
property |
The name of the property to use for the match expression. If specified, |
values |
A vector of values to match against. |
stops |
A vector of corresponding stops (colors, etc.) for the matched values. |
default |
A default value to use if no matches are found. |
A list representing the match expression.
match_expr( column = "category", values = c("A", "B", "C"), stops = c("#ff0000", "#00ff00", "#0000ff"), default = "#cccccc" )
match_expr( column = "category", values = c("A", "B", "C"), stops = c("#ff0000", "#00ff00", "#0000ff"), default = "#cccccc" )
This function allows a layer to be moved to a different z-position in an existing Mapbox GL or Maplibre GL map using a proxy object.
move_layer(proxy, layer_id, before_id = NULL)
move_layer(proxy, layer_id, before_id = NULL)
proxy |
A proxy object created by |
layer_id |
The ID of the layer to move. |
before_id |
The ID of an existing layer to insert the new layer before. Important: this means that the layer will appear immediately behind the layer defined in |
The updated proxy object.
For a given story_section()
, you may want to trigger an event when the section becomes visible.
This function wraps shiny::observeEvent()
to allow you to modify the state of your map or
invoke other Shiny actions on user scroll.
on_section(map_id, section_id, handler)
on_section(map_id, section_id, handler)
map_id |
The ID of your map output |
section_id |
The ID of the section to trigger on, defined in |
handler |
Expression to execute when section becomes visible. |
Render a Mapbox GL output element in Shiny
renderMapboxgl(expr, env = parent.frame(), quoted = FALSE)
renderMapboxgl(expr, env = parent.frame(), quoted = FALSE)
expr |
An expression that generates a Mapbox GL map |
env |
The environment in which to evaluate |
quoted |
Is |
A rendered Mapbox GL map for use in a Shiny server
Render a Mapbox GL Compare output element in Shiny
renderMapboxglCompare(expr, env = parent.frame(), quoted = FALSE)
renderMapboxglCompare(expr, env = parent.frame(), quoted = FALSE)
expr |
An expression that generates a Mapbox GL Compare map |
env |
The environment in which to evaluate |
quoted |
Is |
A rendered Mapbox GL Compare map for use in a Shiny server
Render a Maplibre GL output element in Shiny
renderMaplibre(expr, env = parent.frame(), quoted = FALSE)
renderMaplibre(expr, env = parent.frame(), quoted = FALSE)
expr |
An expression that generates a Maplibre GL map |
env |
The environment in which to evaluate |
quoted |
Is |
A rendered Maplibre GL map for use in a Shiny server
Render a Maplibre GL Compare output element in Shiny
renderMaplibreCompare(expr, env = parent.frame(), quoted = FALSE)
renderMaplibreCompare(expr, env = parent.frame(), quoted = FALSE)
expr |
An expression that generates a Maplibre GL Compare map |
env |
The environment in which to evaluate |
quoted |
Is |
A rendered Maplibre GL Compare map for use in a Shiny server
Set a configuration property for a Mapbox GL map
set_config_property(map, import_id, config_name, value)
set_config_property(map, import_id, config_name, value)
map |
A map object created by the |
import_id |
The name of the imported style to set the config for (e.g., 'basemap'). |
config_name |
The name of the configuration property from the style. |
value |
The value to set for the configuration property. |
The updated map object with the configuration property set.
This function sets a filter on a map layer, working with both regular map objects and proxy objects.
set_filter(map, layer_id, filter)
set_filter(map, layer_id, filter)
map |
A map object created by the |
layer_id |
The ID of the layer to which the filter will be applied. |
filter |
The filter expression to apply. |
The updated map object.
Set fog on a Mapbox GL map
set_fog( map, range = NULL, color = NULL, horizon_blend = NULL, high_color = NULL, space_color = NULL, star_intensity = NULL )
set_fog( map, range = NULL, color = NULL, horizon_blend = NULL, high_color = NULL, space_color = NULL, star_intensity = NULL )
map |
A map object created by the |
range |
A numeric vector of length 2 defining the minimum and maximum range of the fog. |
color |
A string specifying the color of the fog. |
horizon_blend |
A number between 0 and 1 controlling the blending of the fog at the horizon. |
high_color |
A string specifying the color of the fog at higher elevations. |
space_color |
A string specifying the color of the fog in space. |
star_intensity |
A number between 0 and 1 controlling the intensity of the stars in the fog. |
The updated map object.
Set a layout property on a map layer
set_layout_property(map, layer, name, value)
set_layout_property(map, layer, name, value)
map |
A map object created by the |
layer |
The ID of the layer to update. |
name |
The name of the layout property to set. |
value |
The value to set the property to. |
The updated map object.
Set a paint property on a map layer
set_paint_property(map, layer, name, value)
set_paint_property(map, layer, name, value)
map |
A map object created by the |
layer |
The ID of the layer to update. |
name |
The name of the paint property to set. |
value |
The value to set the property to. |
The updated map object.
This function sets the projection dynamically after map initialization.
set_projection(map, projection)
set_projection(map, projection)
map |
A map object created by mapboxgl() or maplibre() functions, or their respective proxy objects |
projection |
A string representing the projection name (e.g., "mercator", "globe", "albers", "equalEarth", etc.) |
The modified map object
Set source of a map layer
set_source(map, layer, source)
set_source(map, layer, source)
map |
A map object created by the |
layer |
The ID of the layer to update. |
source |
An sf object (which will be converted to a GeoJSON source). |
The updated map object.
Update the style of a map
set_style(map, style, config = NULL, diff = TRUE)
set_style(map, style, config = NULL, diff = TRUE)
map |
A map object created by the |
style |
The new style URL to be applied to the map. |
config |
A named list of options to be passed to the style config. |
diff |
A boolean that attempts a diff-based update rather than re-drawing the full style. Not available for all styles. |
The modified map object.
## Not run: map <- mapboxgl( style = mapbox_style("streets"), center = c(-74.006, 40.7128), zoom = 10, access_token = "your_mapbox_access_token" ) # Update the map style in a Shiny app observeEvent(input$change_style, { mapboxgl_proxy("map", session) %>% set_style(mapbox_style("dark"), config = list(showLabels = FALSE), diff = TRUE) }) ## End(Not run)
## Not run: map <- mapboxgl( style = mapbox_style("streets"), center = c(-74.006, 40.7128), zoom = 10, access_token = "your_mapbox_access_token" ) # Update the map style in a Shiny app observeEvent(input$change_style, { mapboxgl_proxy("map", session) %>% set_style(mapbox_style("dark"), config = list(showLabels = FALSE), diff = TRUE) }) ## End(Not run)
Set terrain properties on a map
set_terrain(map, source, exaggeration = 1)
set_terrain(map, source, exaggeration = 1)
map |
A map object created by the |
source |
The ID of the raster DEM source. |
exaggeration |
The terrain exaggeration factor. |
The modified map object with the terrain settings applied.
## Not run: library(mapgl) mapboxgl( style = mapbox_style("standard-satellite"), center = c(-114.26608, 32.7213), zoom = 14, pitch = 80, bearing = 41 ) |> add_raster_dem_source( id = "mapbox-dem", url = "mapbox://mapbox.mapbox-terrain-dem-v1", tileSize = 512, maxzoom = 14 ) |> set_terrain( source = "mapbox-dem", exaggeration = 1.5 ) ## End(Not run)
## Not run: library(mapgl) mapboxgl( style = mapbox_style("standard-satellite"), center = c(-114.26608, 32.7213), zoom = 14, pitch = 80, bearing = 41 ) |> add_raster_dem_source( id = "mapbox-dem", url = "mapbox://mapbox.mapbox-terrain-dem-v1", tileSize = 512, maxzoom = 14 ) |> set_terrain( source = "mapbox-dem", exaggeration = 1.5 ) ## End(Not run)
Set tooltip on a map layer
set_tooltip(map, layer, tooltip)
set_tooltip(map, layer, tooltip)
map |
A map object created by the |
layer |
The ID of the layer to update. |
tooltip |
The name of the tooltip to set. |
The updated map object.
Set the map center and zoom level
set_view(map, center, zoom)
set_view(map, center, zoom)
map |
A map object created by the |
center |
A numeric vector of length 2 specifying the center of the map (longitude, latitude). |
zoom |
The zoom level. |
The updated map object.
This function generates a step expression that can be used in your styles.
step_expr(column = NULL, property = NULL, base, values, stops, na_color = NULL)
step_expr(column = NULL, property = NULL, base, values, stops, na_color = NULL)
column |
The name of the column to use for the step expression. If specified, |
property |
The name of the property to use for the step expression. If specified, |
base |
The base value to use for the step expression. |
values |
A numeric vector of values at which steps occur. |
stops |
A vector of corresponding stops (colors, sizes, etc.) for the steps. |
na_color |
The color to use for missing values. Mapbox GL JS defaults to black if this is not supplied. |
A list representing the step expression.
step_expr( column = "value", base = "#ffffff", values = c(1000, 5000, 10000), stops = c("#ff0000", "#00ff00", "#0000ff") )
step_expr( column = "value", base = "#ffffff", values = c(1000, 5000, 10000), stops = c("#ff0000", "#00ff00", "#0000ff") )
Create a scrollytelling story map with Leaflet
story_leaflet( map_id, sections, root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
story_leaflet( map_id, sections, root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
map_id |
The ID of your mapboxgl, maplibre, or leaflet output
defined in the server, e.g. |
sections |
A named list of story_section objects.
Names will correspond to map events defined within
the server using |
root_margin |
The margin around the viewport for triggering sections by
the intersection observer. Should be specified as a string,
e.g. |
threshold |
A number that indicates the visibility ratio for a story ' panel to be used to trigger a section; should be a number between 0 and 1. Defaults to 0, meaning that the section is triggered as soon as the first pixel is visible. |
styles |
Optional custom CSS styles. Should be specified as a
character string within |
bg_color |
Default background color for all sections |
text_color |
Default text color for all sections |
font_family |
Default font family for all sections |
Create a scrollytelling story map
story_map( map_id, sections, map_type = c("mapboxgl", "maplibre", "leaflet"), root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
story_map( map_id, sections, map_type = c("mapboxgl", "maplibre", "leaflet"), root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
map_id |
The ID of your mapboxgl, maplibre, or leaflet output
defined in the server, e.g. |
sections |
A named list of story_section objects.
Names will correspond to map events defined within
the server using |
map_type |
One of |
root_margin |
The margin around the viewport for triggering sections by
the intersection observer. Should be specified as a string,
e.g. |
threshold |
A number that indicates the visibility ratio for a story ' panel to be used to trigger a section; should be a number between 0 and 1. Defaults to 0, meaning that the section is triggered as soon as the first pixel is visible. |
styles |
Optional custom CSS styles. Should be specified as a
character string within |
bg_color |
Default background color for all sections |
text_color |
Default text color for all sections |
font_family |
Default font family for all sections |
Create a scrollytelling story map with MapLibre
story_maplibre( map_id, sections, root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
story_maplibre( map_id, sections, root_margin = "-20% 0px -20% 0px", threshold = 0, styles = NULL, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
map_id |
The ID of your mapboxgl, maplibre, or leaflet output
defined in the server, e.g. |
sections |
A named list of story_section objects.
Names will correspond to map events defined within
the server using |
root_margin |
The margin around the viewport for triggering sections by
the intersection observer. Should be specified as a string,
e.g. |
threshold |
A number that indicates the visibility ratio for a story ' panel to be used to trigger a section; should be a number between 0 and 1. Defaults to 0, meaning that the section is triggered as soon as the first pixel is visible. |
styles |
Optional custom CSS styles. Should be specified as a
character string within |
bg_color |
Default background color for all sections |
text_color |
Default text color for all sections |
font_family |
Default font family for all sections |
Create a story section for story maps
story_section( title, content, position = c("left", "center", "right"), width = 400, bg_color = NULL, text_color = NULL, font_family = NULL )
story_section( title, content, position = c("left", "center", "right"), width = 400, bg_color = NULL, text_color = NULL, font_family = NULL )
title |
Section title |
content |
Section content - can be text, HTML, or Shiny outputs |
position |
Position of text block ("left", "center", "right") |
width |
Width of text block in pixels (default: 400) |
bg_color |
Background color (with alpha) for text block |
text_color |
Text color |
font_family |
Font family for the section |