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.0 |
Built: | 2025-01-13 21:20:11 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 )
add_categorical_legend( map, legend_title, values, colors, circular_patches = FALSE, position = "top-left", unique_id = NULL, sizes = NULL, add = FALSE, width = 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. |
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 )
add_continuous_legend( map, legend_title, values, colors, position = "top-left", unique_id = NULL, add = FALSE, width = 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. |
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 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 = FALSE )
add_layers_control( map, position = "top-left", layers = NULL, collapsible = FALSE )
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. |
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(collapsible = TRUE) ## 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(collapsible = TRUE) ## 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 )
add_legend( map, legend_title, values, colors, type = c("continuous", "categorical"), circular_patches = FALSE, position = "top-left", sizes = NULL, add = FALSE, width = 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. |
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 swipe between the two maps to compare different styles or data layers.
compare( map1, map2, width = "100%", height = NULL, elementId = NULL, mousemove = FALSE, orientation = "vertical" )
compare( map1, map2, width = "100%", height = NULL, elementId = NULL, mousemove = FALSE, orientation = "vertical" )
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). |
orientation |
A string specifying the orientation of the swiper, either "horizontal" or "vertical". |
A comparison widget.
## Not run: library(mapgl) library(mapgl) m1 <- mapboxgl(style = mapbox_style("light")) m2 <- mapboxgl(style = mapbox_style("dark")) compare(m1, m2) ## End(Not run)
## Not run: library(mapgl) library(mapgl) m1 <- mapboxgl(style = mapbox_style("light")) m2 <- mapboxgl(style = mapbox_style("dark")) compare(m1, m2) ## 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 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 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 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 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 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
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 = "rgba(255,255,255,0.9)", text_color = "#34495e", font_family = NULL )
story_section( title, content, position = c("left", "center", "right"), width = 400, bg_color = "rgba(255,255,255,0.9)", text_color = "#34495e", 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 |