UNPKG

@deck.gl/carto

Version:

CARTO official integration with Deck.gl. Build geospatial applications using CARTO and Deck.gl.

53 lines (45 loc) 1.67 kB
// deck.gl // SPDX-License-Identifier: MIT // Copyright (c) vis.gl contributors import {AccessorFunction, Color} from '@deck.gl/core'; import {scaleLinear} from 'd3-scale'; import {Feature} from 'geojson'; import getPalette, {DEFAULT_PALETTE, NULL_COLOR} from './palette'; import {assert} from '../utils'; import {AttributeSelector, getAttrValue} from './utils'; /** * Helper function for quickly creating a color continuous style. * * Data values of each field are interpolated linearly across values in the domain and * are then styled with a blend of the corresponding color in the range. * * @return accessor that maps objects to `Color` values */ export default function colorContinuous<DataT = Feature>({ attr, domain, colors = DEFAULT_PALETTE, nullColor = NULL_COLOR }: { /** Attribute or column to symbolize by. */ attr: AttributeSelector<DataT, number>; /** Attribute domain to define the data range. */ domain: number[]; /** * Color assigned to each domain value. * * Either Array of colors in RGBA or valid named CARTOColors palette. * @default `PurpOr` */ colors?: string | Color[]; /** Color for null values. @default: [204, 204, 204]*/ nullColor?: Color; }): AccessorFunction<DataT, Color> { assert(Array.isArray(domain), 'Expected "domain" to be an array of numbers'); const palette = typeof colors === 'string' ? getPalette(colors, domain.length) : colors; const color = scaleLinear<Color>().domain(domain).range(palette); return (d, info) => { const value = getAttrValue(attr, d, info); return typeof value === 'number' && Number.isFinite(value) ? color(value) : nullColor; }; }