The SolidPolygon Layer renders filled polygons.
import DeckGL from '@deck.gl/react';
import {SolidPolygonLayer} from '@deck.gl/layers';
new SolidPolygonLayer({
data: [
[[0, 0], [0, 1], [1, 1], [1, 0], [0, 0]], // Simple polygon (array of coords)
[ // Complex polygon with one hole
[[0, 0], [0, 2], [2, 2], [2, 0], [0, 0]], // (array of array of coords)
[[0, 0], [0, 1], [1, 1], [1, 0], [0, 0]]
]
],
getPolygon: d => d,
getColor: [255, 0, 0],
extruded: false
});
To install the dependencies from NPM:
npm install deck.gl
# or
npm install @deck.gl/core @deck.gl/layers
import {SolidPolygonLayer} from '@deck.gl/layers';
new SolidPolygonLayer({});
To use pre-bundled scripts:
<script src="https://unpkg.com/deck.gl@^7.0.0/dist.min.js"></script>
<!-- or -->
<script src="https://unpkg.com/@deck.gl/core@^7.0.0/dist.min.js"></script>
<script src="https://unpkg.com/@deck.gl/layers@^7.0.0/dist.min.js"></script>
new deck.SolidPolygonLayer({});
Inherits from all Base Layer properties.
- Default:
true
Whether to fill the polygons (based on the color provided by the
getFillColor
accessor.
- Default:
false
Whether to extrude the polygons (based on the elevations provided by the
getElevation
accessor. If set to false, all polygons will be flat, this
generates less geometry and is faster than simply returning 0
from getElevation
.
- Default:
false
Whether to generate a line wireframe of the hexagon. The outline will have "horizontal" lines closing the top and bottom polygons and a vertical line (a "strut") for each vertex on the polygon.
- Default:
1
Elevation multiplier. The final elevation is calculated by
elevationScale * getElevation(d)
. elevationScale
is a handy property to scale
all elevation without updating the data.
Remarks:
- These lines are rendered with
GL.LINE
and will thus always be 1 pixel wide. - Wireframe and solid extrusions are exclusive, you'll need to create two layers with the same data if you want a combined rendering effect.
- Default:
true
This is an object that contains material props for lighting effect applied on extruded polygons. Check the lighting guide for configurable settings.
- Default:
true
Note: This prop is experimental
If false
, will skip normalizing the coordinates returned by getPolygon
. Disabling normalization improves performance during data update, but makes the layer prone to error in case the data is malformed. It is only recommended when you use this layer with preprocessed static data or validation on the backend.
When normalization is disabled, polygons must be specified in the format of flat array or {positions, holeIndices}
. Rings must be closed (i.e. the first and last vertices must be identical). See getPolygon
below for details.
getPolygon
(Function, optional) data:image/s3,"s3://crabby-images/fc1cd/fc1cdd9ea047c67babc1b9d153a7ccc0c1a5781d" alt="transition-enabled"
- Default:
object => object.polygon
This accessor returns the polygon corresponding to an object in the data
stream.
A polygon can be one of the following formats:
- An array of points (
[x, y, z]
) - a.k.a. a "ring". - An array of rings. The first ring is the exterior boundary and the following rings are the holes. Compatible with the GeoJSON Polygon specification.
- A flat array or TypedArray of numbers, in the shape of
[x0, y0, z0, x1, y1, z1, ...]
, is equivalent to a single ring. By default, each coordinate is assumed to contain 3 consecutive numbers. If each coordinate contains only two numbers (x, y), set thepositionFormat
prop of the layer toXY
. - An object of shape
{positions, holeIndices}
.positions
(Array|TypedArray) - a flat array of coordinates. By default, each coordinate is assumed to contain 3 consecutive numbers. If each coordinate contains only two numbers (x, y), set thepositionFormat
prop of the layer toXY
.holeIndices
(Array) - the starting index of each hole in thepositions
array. The first ring is the exterior boundary and the successive rings are the holes.
getFillColor
(Function|Array, optional) data:image/s3,"s3://crabby-images/fc1cd/fc1cdd9ea047c67babc1b9d153a7ccc0c1a5781d" alt="transition-enabled"
- Default:
[0, 0, 0, 255]
The rgba fill color of each object's polygon, in r, g, b, [a]
. Each component is in the 0-255 range.
- If an array is provided, it is used as the fill color for all polygons.
- If a function is provided, it is called on each polygon to retrieve its fill color.
getLineColor
(Function|Array, optional) data:image/s3,"s3://crabby-images/fc1cd/fc1cdd9ea047c67babc1b9d153a7ccc0c1a5781d" alt="transition-enabled"
- Default:
[0, 0, 0, 255]
The rgba wireframe color of each object's polygon, in r, g, b, [a]
. Each component is in the 0-255 range.
Only applies if extruded: true
.
- If an array is provided, it is used as the stroke color for all polygons.
- If a function is provided, it is called on each object to retrieve its stroke color.
getElevation
(Function|Number, optional) data:image/s3,"s3://crabby-images/fc1cd/fc1cdd9ea047c67babc1b9d153a7ccc0c1a5781d" alt="transition-enabled"
- Default:
1000
The elevation to extrude each polygon with.
If a cartographic projection mode is used, height will be interpreted as meters,
otherwise will be in unit coordinates.
Only applies if extruded: true
.
- If a number is provided, it is used as the elevation for all polygons.
- If a function is provided, it is called on each object to retrieve its elevation.
- This layer only renders filled polygons. If you need to render polygon
outlines, use the
PathLayer
- Polygons are always closed, i.e. there is an implicit line segment between the first and last vertices, when those vertices are not equal.
- The specification of complex polygons intentionally follows the GeoJson conventions for representing polygons with holes.