import {ContourLayerDemo} from 'website-components/doc-demos/aggregation-layers';
ContourLayer renders Isolines or Isobands for a given threshold and cell size. Isoline represents collection of line segments that separate the area above and below a given threshold. Isoband represents a collection of polygons (filled) that fill the area containing values in a given threshold range. To generate an Isoline single threshold value is needed, to generate an Isoband an Array with two values needed. Data is first aggregated using given cell size and resulting scalar field is used to run Marching Squares algorithm that generates a set of vertices to form Isolines or Isobands. In below documentation Isoline and Isoband is referred as contour.
import DeckGL from '@deck.gl/react';
import {ContourLayer} from '@deck.gl/aggregation-layers';
const CONTOURS = [
{threshold: 1, color: [255, 0, 0, 255], strokeWidth: 1}, // => Isoline for threshold 1
{threshold: 5, color: [0, 255, 0], strokeWidth: 2}, // => Isoline for threshold 5
{threshold: [6, 10], color: [0, 0, 255, 128]} // => Isoband for threshold range [6, 10)
];
function App({data, viewState}) {
/**
* Data format:
* [
* {COORDINATES: [-122.42177834, 37.78346622]},
* ...
* ]
*/
const layer = new ContourLayer({
id: 'contourLayer',
// Three contours are rendered.
contours: CONTOURS,
cellSize: 200,
getPosition: d => d.COORDINATES,
});
return <DeckGL viewState={viewState}
layers={[layer]}
getTooltip={({object}) => object && } />;
}To install the dependencies from NPM:
npm install deck.gl
# or
npm install @deck.gl/core @deck.gl/layers @deck.gl/aggregation-layersimport {ContourLayer} from '@deck.gl/aggregation-layers';
new ContourLayer({});To use pre-bundled scripts:
<script src="https://unpkg.com/deck.gl@^8.0.0/dist.min.js"></script>
<!-- or -->
<script src="https://unpkg.com/@deck.gl/core@^8.0.0/dist.min.js"></script>
<script src="https://unpkg.com/@deck.gl/layers@^8.0.0/dist.min.js"></script>
<script src="https://unpkg.com/@deck.gl/aggregation-layers@^8.0.0/dist.min.js"></script>new deck.ContourLayer({});Inherits from all Base Layer properties.
- Default:
1000
Size of each cell in meters
- Default: true
When set to true and browser supports GPU aggregation, aggregation is performed on GPU. GPU aggregation can be 2 to 3 times faster depending upon number of points and number of cells.
NOTE: GPU Aggregation requires WebGL2 support by the browser. When gpuAggregation is set to true and browser doesn't support WebGL2, aggregation falls back to CPU.
- Default: 'SUM'
Defines the type of aggregation operation, valid values are 'SUM', 'MEAN', 'MIN' and 'MAX'. When no value or an invalid value is set, 'SUM' is used as aggregation.
- SUM : Grid cell contains sum of all weights that fall into it.
- MEAN : Grid cell contains mean of all weights that fall into it.
- MIN : Grid cell contains minimum of all weights that fall into it.
- MAX : Grid cell contains maximum of all weights that fall into it.
- Default:
[{threshold: 1}]
Array of objects with following keys
-
threshold(Number or Array) :- Isolines:
thresholdvalue must be a singleNumber, Isolines are generated based on this threshold value. - Isobands:
thresholdvalue must be an Array of twoNumbers. Isobands are generated using[threshold[0], threshold[1])as threshold range, i.e area that has values>= threshold[0]and< threshold[1]are rendered with corresponding color. NOTE:threshold[0]is inclusive andthreshold[1]is not inclusive.
- Isolines:
-
color(Array, optional) : RGBA color array to be used to render the contour, if not specified a default value of[255, 255, 255, 255]is used. When a three component RGB array specified, a default value of 255 is used for Alpha. -
strokeWidth(Number, optional) : Applicable forIsolines only, width of the Isoline in pixels, if not specified a default value of1is used. -
zIndex(Number, optional) : Defines z order of the contour. Contour with higherzIndexvalue is rendered above contours with lowerzIndexvalues. When visualizing overlapping contours,zIndexalong withzOffset(defined below) can be used to precisely layout contours. This also avoids z-fighting rendering issues. If not specified a unique value from0ton(number of contours) is assigned.
NOTE: Like any other layer prop, a shallow comparison is performed on contours prop to determine if it is changed. This prop should be set to an array object, that changes only when contours need to be changed.
- Default:
0.005
A very small z offset that is added for each vertex of a contour (Isoline or Isoband). This is needed to control the layout of contours, especially when rendering overlapping contours. Imagine a case where an Isoline is specified which is overlapped with an Isoband. To make sure the Isoline is visible we need to render this above the Isoband.
getPosition (Function, optional)
- Default:
object => object.position
Method called to retrieve the position of each object.
getWeight (Function, optional)
- Default:
1
The weight of each object.
- If a number is provided, it is used as the weight for all objects.
- If a function is provided, it is called on each object to retrieve its weight.
The ContourLayer renders the following sublayers:
lines- For Isolines, rendered by LineLayerbands- For Isobands, rendered by SolidPolygonLayer