@deck.gl/mapbox
This module integrates deck.gl into the Mapbox GL JS API-compatible ecosystem.
- It synchronizes a deck.gl
MapView
with the mapbox-gl/maplibre-gl camera. - It allows deck.gl to be used with mapbox-gl/maplibre-gl controls and plugins such as
NavigationControl
,GeolocateControl
andmapbox-gl-geocoder
. - It adds the option to interleave deck.gl layers with the base map layers, such as drawing behind map labels, z-occlusion between deck.gl 3D objects and buildings, etc.
This module may be used in the React, Pure JS, and Scripting Environments. Visit the mapbox base map developer guide for examples of each option.
When you use this module, Mapbox/Maplibre is the root HTML element and deck.gl is the child, with the map library handling all user inputs. Some of deck.gl's features are therefore unavailable due to limitations of the map library's API, see limitations.
It may be easier to understand the concepts of the module if you are already a mapbox-gl/maplibre-gl developer.
data:image/s3,"s3://crabby-images/4cecd/4cecd77be2692d7961775cec194eb401e794c019" alt=""
Installation
Include the Standalone Bundle
<script src='https://api.tiles.mapbox.com/mapbox-gl-js/v3.2.0/mapbox-gl.js'></script>
<!-- or -->
<script src='https://unpkg.com/maplibre-gl@5.0.0/dist/maplibre-gl.js'></script>
<script src="https://unpkg.com/deck.gl@^9.0.0/dist.min.js"></script>
<script type="text/javascript">
const {MapboxOverlay} = deck;
</script>
Install from NPM
npm install @deck.gl/mapbox
import {MapboxOverlay} from '@deck.gl/mapbox';
Camera Synchronization between deck.gl and Mapbox
This module keeps a deck.gl MapView
or GlobeView
in sync with the mapbox-gl/maplibre-gl camera so that the base map and deck layers are always geospactially aligned. Some Deck
props, such as viewState
, are ignored or have different behavior. See MapboxOverlay
constructor notes. Also, some camera features are unable to be fully synchronized due to API limitations, see limitations.
Using mapbox-gl/maplibre-gl controls and plugins with deck.gl
The Mapbox ecosystem offers many well-designed controls, from the basic functionalities of NavigationControl
, Popup
and GeolocateControl
, to vendor-service-bound UI implementations such as mapbox-gl-geocoder
and mapbox-gl-directions
. These libraries require that the Mapbox Map holds the source of truth of the camera state, instead of the normal state management by Deck
. When you use the MapboxOverlay
classes from this module, deck.gl plays nice with all the mapbox-gl peripherals.
Mixing deck.gl layers and Map layers
Some important information in the base map could be hidden by a deck.gl visualization layer, and controlling opacity is not enough. A typical example of this is labels and roads, where it is desirable to have a deck.gl visualization layer render on top of the Mapbox geography, but where one might still want to see e.g. labels and/or roads. Alternatively, the deck.gl visualization should cover the ground, but not the roads and labels.
To inject a deck layer into the map layers stack add an interleaved: true
props to the MapboxOverlay control and add a beforeId
prop to any layer passed to the MapboxOverlay control.
Mapbox provides an example of finding the first label layer. For more sophisticated injection point lookups, refer to Mapbox' documentation on the format of Mapbox style layers, see Mapbox Style Spec.
In some cases, the application wants to add a deck.gl 3D layer (e.g. ArcLayer, HexagonLayer, GeoJsonLayer) on top of a Mapbox basemap, while seamlessly blend into the z-buffer. This will interleave the useful visualization layers from both the deck.gl and Mapbox layer catalogs. In this case, a beforeId
is not needed.
Interleaved Renderer Compatibility
The following table details renderer support across different versions of mapbox-gl and maplibre-gl. See base map renderers to learn about the differences between overlaid and interleaved renderers.
Library | Overlaid (default) | Interleaved |
---|---|---|
mapbox-gl-js (before v2.13) | ✓ | |
mapbox-gl-js v2.13+ | ✓ | ✓ with useWebGL2: true |
mapbox-gl-js v3+ | ✓ | ✓ |
maplibre-gl-js (before v3) | ✓ | |
maplibre-gl-js v3+ | ✓ | ✓* |
*will fallback to WebGL1 if WebGL2 is not available
Alternative Mapbox Integrations
If you're using deck.gl in a React or Scripting environment, you just want the base map as a back drop, and do not need mapbox-gl's UI controls or need to mix deck.gl and Mapbox layers, it is recommended that you do not use this module and instead use deck.gl as the root HTML element. Visit Using Deck.gl as the root HTML element for an example.
Limitations
- When using deck.gl's multi-view system, only one of the views can match the base map and receive interaction. See using MapboxOverlay with multi-views for details.
- When using deck.gl as Mapbox layers or controls,
Deck
only receives a subset of user inputs delegated byMap
. Therefore, certain interactive callbacks likeonDrag
,onInteractionStateChange
are not available. - Mapbox/MapLibre's terrain features are partially supported. When a terrain is used, the camera of deck.gl and the base map should synchronize, however the deck.gl data with z=0 are rendered at the sea level and not aligned with the terrain surface.
- Mapbox's non-Mercator projections are not supported as their API doesn't expose the parameters used. Maplibre's globe projection is fully supported.
- The
position
property inviewState
has no equivalent in mapbox-gl.