UNPKG

kepler.gl.geoiq

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

125 lines (104 loc) 16.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.getBinColorDomain = getBinColorDomain; exports.getColorScaleFunction = getColorScaleFunction; exports.getColorValueDomain = getColorValueDomain; exports.getElevationScaleFunction = getElevationScaleFunction; exports.getRadiusScaleFunction = getRadiusScaleFunction; exports.getScaleFunctor = getScaleFunctor; exports.needReCalculateScaleFunction = needReCalculateScaleFunction; exports.needsRecalculateColorDomain = needsRecalculateColorDomain; exports.needsRecalculateRadiusRange = needsRecalculateRadiusRange; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _dataUtils = require("../../utils/data-utils"); var _defaultSettings = require("../../constants/default-settings"); // Copyright (c) 2023 Uber Technologies, Inc. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to deal // in the Software without restriction, including without limitation the rights // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell // copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. // Enable render color by customized color Scale function getBinColorDomain(scaleType, bins, _ref) { var _ref2 = (0, _slicedToArray2["default"])(_ref, 2), lowerIdx = _ref2[0], upperIdx = _ref2[1]; switch (scaleType) { case _defaultSettings.SCALE_TYPES.quantize: return [bins[lowerIdx].value, bins[upperIdx].value]; case _defaultSettings.SCALE_TYPES.quantile: return bins.slice(lowerIdx, upperIdx + 1).map(function (d) { return d.value; }); case _defaultSettings.SCALE_TYPES.ordinal: return (0, _dataUtils.unique)(bins.map(function (b) { return b.value; })).sort(); default: return [bins[lowerIdx].value, bins[upperIdx].value]; } } function getScaleFunctor(scaleType) { return _defaultSettings.SCALE_FUNC[scaleType] || _defaultSettings.SCALE_FUNC.quantile; } function getColorValueDomain(layer) { var _layer$props = layer.props, lowerPercentile = _layer$props.lowerPercentile, upperPercentile = _layer$props.upperPercentile, colorScale = _layer$props.colorScale; var sortedBins = layer.state.sortedColorBins.sortedBins; var len = sortedBins.length; if (!len) { // err... what do we do layer.state.colorValueDomain = null; } else { var lowerIdx = Math.ceil(lowerPercentile / 100 * (len - 1)); var upperIdx = Math.floor(upperPercentile / 100 * (len - 1)); // calculate valueDomain based on layer.state.colorValueDomain = getBinColorDomain(colorScale, sortedBins, [lowerIdx, upperIdx]); layer.getColorScale(); } layer.props.onSetColorDomain(layer.state.colorValueDomain); } function getColorScaleFunction(layer) { var _layer$props2 = layer.props, colorScale = _layer$props2.colorScale, colorDomain = _layer$props2.colorDomain; layer.state.colorScaleFunc = getScaleFunctor(colorScale)().domain(colorDomain || layer.state.colorDomain || layer.state.colorValueDomain).range(layer.props.colorRange); } function getElevationScaleFunction(layer) { var elevationRange = layer.props.elevationRange; var elevationDomain = layer.props.elevationDomain || layer.state.elevationValueDomain; layer.state.elevationScaleFunc = getScaleFunctor(layer.props.sizeScale)().domain(elevationDomain).range(elevationRange); } function getRadiusScaleFunction(layer) { var viewport = layer.context.viewport; layer.state.radiusScaleFunc = _defaultSettings.SCALE_FUNC.sqrt().domain(layer.state.radiusDomain).range(layer.props.radiusRange.map(function (d) { return d * viewport.distanceScales.metersPerPixel[0]; })); } function needsRecalculateColorDomain(oldProps, props) { return oldProps.lowerPercentile !== props.lowerPercentile || oldProps.upperPercentile !== props.upperPercentile || oldProps.colorScale !== props.colorScale; } function needReCalculateScaleFunction(oldProps, props) { return oldProps.colorRange !== props.colorRange; } function needsRecalculateRadiusRange(oldProps, props) { return oldProps.radiusRange !== props.radiusRange && (oldProps.radiusRange[0] !== props.radiusRange[0] || oldProps.radiusRange[1] !== props.radiusRange[1]); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/deckgl-layers/layer-utils/utils.js"],"names":["getBinColorDomain","scaleType","bins","lowerIdx","upperIdx","SCALE_TYPES","quantize","value","quantile","slice","map","d","ordinal","b","sort","getScaleFunctor","SCALE_FUNC","getColorValueDomain","layer","props","lowerPercentile","upperPercentile","colorScale","sortedBins","state","sortedColorBins","len","length","colorValueDomain","Math","ceil","floor","getColorScale","onSetColorDomain","getColorScaleFunction","colorDomain","colorScaleFunc","domain","range","colorRange","getElevationScaleFunction","elevationRange","elevationDomain","elevationValueDomain","elevationScaleFunc","sizeScale","getRadiusScaleFunction","viewport","context","radiusScaleFunc","sqrt","radiusDomain","radiusRange","distanceScales","metersPerPixel","needsRecalculateColorDomain","oldProps","needReCalculateScaleFunction","needsRecalculateRadiusRange"],"mappings":"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","sourcesContent":["// Copyright (c) 2023 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {unique} from 'utils/data-utils';\n\nimport {SCALE_TYPES, SCALE_FUNC} from 'constants/default-settings';\n\n// Enable render color by customized color Scale\nexport function getBinColorDomain(scaleType, bins, [lowerIdx, upperIdx]) {\n  switch (scaleType) {\n    case SCALE_TYPES.quantize:\n      return [bins[lowerIdx].value, bins[upperIdx].value];\n\n    case SCALE_TYPES.quantile:\n      return bins.slice(lowerIdx, upperIdx + 1).map(d => d.value);\n    case SCALE_TYPES.ordinal:\n      return unique(bins.map(b => b.value)).sort();\n    default:\n      return [bins[lowerIdx].value, bins[upperIdx].value];\n  }\n}\n\nexport function getScaleFunctor(scaleType) {\n  return SCALE_FUNC[scaleType] || SCALE_FUNC.quantile;\n}\n\nexport function getColorValueDomain(layer) {\n  const {lowerPercentile, upperPercentile, colorScale} = layer.props;\n  const {sortedBins} = layer.state.sortedColorBins;\n  const len = sortedBins.length;\n\n  if (!len) {\n    // err... what do we do\n    layer.state.colorValueDomain = null;\n  } else {\n    const lowerIdx = Math.ceil(lowerPercentile / 100 * (len - 1));\n    const upperIdx = Math.floor(upperPercentile / 100 * (len - 1));\n\n    // calculate valueDomain based on\n    layer.state.colorValueDomain = getBinColorDomain(colorScale, sortedBins, [\n      lowerIdx,\n      upperIdx\n    ]);\n    layer.getColorScale();\n  }\n\n  layer.props.onSetColorDomain(layer.state.colorValueDomain);\n}\n\nexport function getColorScaleFunction(layer) {\n  const {colorScale, colorDomain} = layer.props;\n  layer.state.colorScaleFunc = getScaleFunctor(colorScale)()\n    .domain(\n      colorDomain || layer.state.colorDomain || layer.state.colorValueDomain\n    )\n    .range(layer.props.colorRange);\n}\n\nexport function getElevationScaleFunction(layer) {\n  const elevationRange = layer.props.elevationRange;\n  const elevationDomain = layer.props.elevationDomain || layer.state.elevationValueDomain;\n\n  layer.state.elevationScaleFunc = getScaleFunctor(layer.props.sizeScale)()\n    .domain(elevationDomain)\n    .range(elevationRange);\n}\n\nexport function getRadiusScaleFunction(layer) {\n  const {viewport} = layer.context;\n  layer.state.radiusScaleFunc = SCALE_FUNC.sqrt()\n    .domain(layer.state.radiusDomain)\n    .range(\n      layer.props.radiusRange.map(\n        d => d * viewport.distanceScales.metersPerPixel[0]\n      )\n    );\n}\n\nexport function needsRecalculateColorDomain(oldProps, props) {\n  return (\n    oldProps.lowerPercentile !== props.lowerPercentile ||\n    oldProps.upperPercentile !== props.upperPercentile ||\n    oldProps.colorScale !== props.colorScale\n  );\n}\n\nexport function needReCalculateScaleFunction(oldProps, props) {\n  return oldProps.colorRange !== props.colorRange;\n}\n\nexport function needsRecalculateRadiusRange(oldProps, props) {\n  return (\n    oldProps.radiusRange !== props.radiusRange &&\n    (oldProps.radiusRange[0] !== props.radiusRange[0] ||\n      oldProps.radiusRange[1] !== props.radiusRange[1])\n  );\n}\n"]}