A WebGL overlay suite consists of multiple layers.
npm install --save deck.gl
import {
WebGLOverlay,
/* import layers here */
} from 'deck.gl';
const mapState = {
latitude: 37.55,
longitude: -122.2,
zoom: 9,
...
}
<WebGLOverlay
width={1920}
height={1080}
mapState={mapState}, // optional
layers={[/* put layer instances here */]}
/>
-
webgl-overlay A react component that takes in viewport parameters, layer instances and generates an overlay consists of single/multiple layers sharing the same rendering context. Internally, the webgl-overlay initializes a WebGL context attached to a canvas element, sets up the animation loop and calls provided callbacks on initial load and for each rendering frames. The webgl-overlay also handles events propagation across layers, and prevents unnecessary calculation taking advantage of the react lifecycle functions.
Parameters
width
(number, required) width of the canvasheight
(number, required) height of the canvaslongitude
(number, required) longitude of the map centerlatitude
(number, required) latitude of the map centerzoom
(number, required) zoom level of the map
Callbacks
onAfterRender
[function, optional] callback after rendering is finished for the current frame
The Choropleth Layer takes in GeoJson formatted data and renders it as interactive choropleths.
Common Parameters
id
(string, required): layer IDwidth
(number, required) width of the layerheight
(number, required) height of the layerlongitude
(number, required) longitude of the map centerlatitude
(number, required) latitude of the map centerzoom
(number, required) zoom level of the mapopacity
(number, required) opacity of the layerlayerIndex
[number, optional, default=0] index of the layerisPickable
[bool, optional, default=false] whether layer responses to mouse events
Layer-specific Parameters
data
(object, required) input data in GeoJson formatdrawContour
[bool, optional, default=false] draw choropleth contour if true, else fill choropleth area
Callbacks
-
onChoroplethHovered
[function, optional] bubbles choropleth properties when mouse hovering -
onChoroplethClicked
[function, optional] bubbles choropleth properties when mouse clicking -
The Hexagon Layer takes in a list of hexagon objects and renders them as interactive hexagons.
Common Parameters
id
(string, required): layer IDwidth
(number, required) width of the layerheight
(number, required) height of the layeropacity
(number, required) opacity of the layerlayerIndex
[number, optional, default=0] index of the layerisPickable
[bool, optional, default=false] whether layer responses to mouse events
Layer-specific Parameters
data
(array, required) array of hexagon objects: [{ centroid, vertices, color }, ...]dotRadius
[number, optional, default=10] radius of each hexagonelevation
[number, optional, default=0.02] height scale of hexagonslightingEnabled
[bool, optional, default=false] whether lighting is enabled
Callbacks
onHexagonHovered
[function, optional] bubbles selection index when mouse hoveringonHexagonClicked
[function, optional] bubbles selection index when mouse clicking
-
The Scatterplot Layer takes in and renders an array of latitude and longitude coordinated points.
Common Parameters
id
(string, required): layer IDwidth
(number, required) width of the layerheight
(number, required) height of the layeropacity
(number, required) opacity of the layerlayerIndex
[number, optional, default=0] index of the layerisPickable
[bool, optional, default=false] whether layer responses to mouse events
Layer-specific Parameters
data
(array, required) array of objects: [{ position, color }, ...]radius
[number, optional, default=10] radius of each marker
-
The Arc Layer takes in paired latitude and longitude coordinated points and render them as arcs that links the starting and ending points.
Common Parameters
id
(string, required): layer IDwidth
(number, required) width of the layerheight
(number, required) height of the layeropacity
(number, required) opacity of the layerlayerIndex
[number, optional, default=0] index of the layerisPickable
[bool, optional, default=false] whether layer responses to mouse events
Layer-specific Parameters
data
(array, required) array of objects: [{ position: {x0, y0, x1, y1}, color }, ...]
-
The Grid Layer takes in an array of latitude and longitude coordinated points, aggregates them into histogram bins and renders as a grid.
Common Parameters
id
(string, required): layer IDwidth
(number, required) width of the layerheight
(number, required) height of the layeropacity
(number, required) opacity of the layerlayerIndex
[number, optional, default=0] index of the layerisPickable
[bool, optional, default=false] whether layer responses to mouse events
Layer-specific Parameters
data
(array, required) array of objects: [{ position, color }, ...]unitWidth
[number, optional, default=100] unit width of the binsunitHeight
[number, optional, default=100] unit height of the bins
npm run start