UNPKG

kepler.gl

Version:

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

329 lines (284 loc) 32.9 kB
"use strict"; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard"); var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.clusterAggregation = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _layers = require("@deck.gl/layers"); var _aggregationLayers = require("@deck.gl/aggregation-layers"); var _geoViewport = _interopRequireDefault(require("@mapbox/geo-viewport")); var _cpuAggregator = _interopRequireWildcard(require("../layer-utils/cpu-aggregator")); var _viewportMercatorProject = require("viewport-mercator-project"); var _d3Array = require("d3-array"); var _layerFactory = require("../../layers/layer-factory"); var _defaultSettings = require("../../constants/default-settings"); var _colorRanges = require("../../constants/color-ranges"); var _clusterUtils = _interopRequireWildcard(require("../layer-utils/cluster-utils")); function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } } var defaultRadius = _layerFactory.LAYER_VIS_CONFIGS.clusterRadius.defaultValue; var defaultRadiusRange = _layerFactory.LAYER_VIS_CONFIGS.clusterRadiusRange.defaultValue; var defaultGetColorValue = function defaultGetColorValue(points) { return points.length; }; var defaultGetRadiusValue = function defaultGetRadiusValue(cell) { return cell.filteredPoints ? cell.filteredPoints.length : cell.points.length; }; function processGeoJSON(step, props, aggregation, _ref) { var viewport = _ref.viewport; var data = props.data, getPosition = props.getPosition, filterData = props.filterData; var geoJSON = (0, _clusterUtils.getGeoJSON)(data, getPosition, filterData); var clusterBuilder = new _clusterUtils["default"](); this.setState({ geoJSON: geoJSON, clusterBuilder: clusterBuilder }); } function getClusters(step, props, aggregation, _ref2) { var viewport = _ref2.viewport; var _this$state = this.state, geoJSON = _this$state.geoJSON, clusterBuilder = _this$state.clusterBuilder; var clusterRadius = props.clusterRadius, zoom = props.zoom, width = props.width, height = props.height; var longitude = viewport.longitude, latitude = viewport.latitude; // zoom needs to be an integer for the different map utils. Also helps with cache key. var bbox = _geoViewport["default"].bounds([longitude, latitude], zoom, [width, height]); var clusters = clusterBuilder.clustersAtZoom({ bbox: bbox, clusterRadius: clusterRadius, geoJSON: geoJSON, zoom: zoom }); this.setState({ layerData: { data: clusters } }); } function getSubLayerRadius(dimensionState, dimension, layerProps) { return function (cell) { var getRadiusValue = layerProps.getRadiusValue; var scaleFunc = dimensionState.scaleFunc; return scaleFunc(getRadiusValue(cell)); }; } var clusterAggregation = { key: 'position', updateSteps: [{ key: 'geojson', triggers: { position: { prop: 'getPosition', updateTrigger: 'getPosition' }, filterData: { prop: 'filterData', updateTrigger: 'filterData' } }, updater: processGeoJSON }, { key: 'clustering', triggers: { clusterRadius: { prop: 'clusterRadius' }, zoom: { prop: 'zoom' }, width: { prop: 'width' }, height: { prop: 'height' } }, updater: getClusters }] }; exports.clusterAggregation = clusterAggregation; function getRadiusValueDomain(step, props, dimensionUpdater) { var key = dimensionUpdater.key; var getRadiusValue = props.getRadiusValue; var layerData = this.state.layerData; var valueDomain = [0, (0, _d3Array.max)(layerData.data, getRadiusValue)]; this._setDimensionState(key, { valueDomain: valueDomain }); } var clusterLayerDimensions = [_cpuAggregator.defaultColorDimension, { key: 'radius', accessor: 'getRadius', nullValue: 0, updateSteps: [{ key: 'getDomain', triggers: { value: { prop: 'getRadiusValue', updateTrigger: 'getRadiusValue' } }, updater: getRadiusValueDomain }, { key: 'getScaleFunc', triggers: { domain: { prop: 'radiusDomain' }, range: { prop: 'radiusRange' }, scaleType: { prop: 'radiusScaleType' } }, updater: _cpuAggregator.getDimensionScale }], getSubLayerAccessor: getSubLayerRadius, getPickingInfo: function getPickingInfo(dimensionState, cell, layerProps) { var radiusValue = layerProps.getRadiusValue(cell); return { radiusValue: radiusValue }; } }]; var defaultProps = { clusterRadius: defaultRadius, colorDomain: null, colorRange: _colorRanges.DEFAULT_COLOR_RANGE, colorScaleType: _defaultSettings.SCALE_TYPES.quantize, radiusScaleType: _defaultSettings.SCALE_TYPES.sqrt, radiusRange: defaultRadiusRange, getPosition: { type: 'accessor', value: function value(x) { return x.position; } }, getColorValue: { type: 'accessor', value: defaultGetColorValue }, getRadiusValue: { type: 'accessor', value: defaultGetRadiusValue } }; var ClusterLayer = /*#__PURE__*/function (_AggregationLayer) { (0, _inherits2["default"])(ClusterLayer, _AggregationLayer); var _super = _createSuper(ClusterLayer); function ClusterLayer() { (0, _classCallCheck2["default"])(this, ClusterLayer); return _super.apply(this, arguments); } (0, _createClass2["default"])(ClusterLayer, [{ key: "initializeState", value: function initializeState() { var cpuAggregator = new _cpuAggregator["default"]({ aggregation: clusterAggregation, dimensions: clusterLayerDimensions }); this.state = { cpuAggregator: cpuAggregator, aggregatorState: cpuAggregator.state }; var attributeManager = this.getAttributeManager(); attributeManager.add({ positions: { size: 3, accessor: 'getPosition' } }); } }, { key: "updateState", value: function updateState(_ref3) { var oldProps = _ref3.oldProps, props = _ref3.props, changeFlags = _ref3.changeFlags; this.setState({ // make a copy of the internal state of cpuAggregator for testing aggregatorState: this.state.cpuAggregator.updateState({ oldProps: oldProps, props: props, changeFlags: changeFlags }, { viewport: this.context.viewport, attributes: this.getAttributes(), numInstances: this.getNumInstances(props) }) }); } }, { key: "getPickingInfo", value: function getPickingInfo(_ref4) { var info = _ref4.info; return this.state.cpuAggregator.getPickingInfo({ info: info }, this.props); } }, { key: "_getSublayerUpdateTriggers", value: function _getSublayerUpdateTriggers() { return this.state.cpuAggregator.getUpdateTriggers(this.props); } }, { key: "_getSubLayerAccessors", value: function _getSubLayerAccessors() { return { getRadius: this.state.cpuAggregator.getAccessor('radius', this.props), getFillColor: this.state.cpuAggregator.getAccessor('fillColor', this.props) }; } }, { key: "renderLayers", value: function renderLayers() { // for subclassing, override this method to return // customized sub layer props var _this$props = this.props, id = _this$props.id, radiusScale = _this$props.radiusScale; var cpuAggregator = this.state.cpuAggregator; // base layer props var _this$props2 = this.props, visible = _this$props2.visible, opacity = _this$props2.opacity, pickable = _this$props2.pickable, autoHighlight = _this$props2.autoHighlight, highlightColor = _this$props2.highlightColor; var updateTriggers = this._getSublayerUpdateTriggers(); var accessors = this._getSubLayerAccessors(); var distanceScale = (0, _viewportMercatorProject.getDistanceScales)(this.context.viewport); var metersPerPixel = distanceScale.metersPerPixel[0]; // return props to the sublayer constructor return new _layers.ScatterplotLayer(_objectSpread({ id: "".concat(id, "-cluster"), data: cpuAggregator.state.layerData.data, radiusScale: metersPerPixel * radiusScale, visible: visible, opacity: opacity, pickable: pickable, autoHighlight: autoHighlight, highlightColor: highlightColor, updateTriggers: updateTriggers }, accessors)); } }]); return ClusterLayer; }(_aggregationLayers._AggregationLayer); exports["default"] = ClusterLayer; ClusterLayer.layerName = 'ClusterLayer'; ClusterLayer.defaultProps = defaultProps; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/deckgl-layers/cluster-layer/cluster-layer.js"],"names":["defaultRadius","LAYER_VIS_CONFIGS","clusterRadius","defaultValue","defaultRadiusRange","clusterRadiusRange","defaultGetColorValue","points","length","defaultGetRadiusValue","cell","filteredPoints","processGeoJSON","step","props","aggregation","viewport","data","getPosition","filterData","geoJSON","clusterBuilder","ClusterBuilder","setState","getClusters","state","zoom","width","height","longitude","latitude","bbox","geoViewport","bounds","clusters","clustersAtZoom","layerData","getSubLayerRadius","dimensionState","dimension","layerProps","getRadiusValue","scaleFunc","clusterAggregation","key","updateSteps","triggers","position","prop","updateTrigger","updater","getRadiusValueDomain","dimensionUpdater","valueDomain","_setDimensionState","clusterLayerDimensions","defaultColorDimension","accessor","nullValue","value","domain","range","scaleType","getDimensionScale","getSubLayerAccessor","getPickingInfo","radiusValue","defaultProps","colorDomain","colorRange","DEFAULT_COLOR_RANGE","colorScaleType","SCALE_TYPES","quantize","radiusScaleType","sqrt","radiusRange","type","x","getColorValue","ClusterLayer","cpuAggregator","CPUAggregator","dimensions","aggregatorState","attributeManager","getAttributeManager","add","positions","size","oldProps","changeFlags","updateState","context","attributes","getAttributes","numInstances","getNumInstances","info","getUpdateTriggers","getRadius","getAccessor","getFillColor","id","radiusScale","visible","opacity","pickable","autoHighlight","highlightColor","updateTriggers","_getSublayerUpdateTriggers","accessors","_getSubLayerAccessors","distanceScale","metersPerPixel","ScatterplotLayer","AggregationLayer","layerName"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 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 {ScatterplotLayer} from '@deck.gl/layers';\nimport {_AggregationLayer as AggregationLayer} from '@deck.gl/aggregation-layers';\n\nimport geoViewport from '@mapbox/geo-viewport';\nimport CPUAggregator, {\n  defaultColorDimension,\n  getDimensionScale\n} from '../layer-utils/cpu-aggregator';\nimport {getDistanceScales} from 'viewport-mercator-project';\nimport {max} from 'd3-array';\n\nimport {LAYER_VIS_CONFIGS} from 'layers/layer-factory';\nimport {SCALE_TYPES} from 'constants/default-settings';\nimport {DEFAULT_COLOR_RANGE} from 'constants/color-ranges';\nimport ClusterBuilder, {getGeoJSON} from '../layer-utils/cluster-utils';\n\nconst defaultRadius = LAYER_VIS_CONFIGS.clusterRadius.defaultValue;\nconst defaultRadiusRange = LAYER_VIS_CONFIGS.clusterRadiusRange.defaultValue;\n\nconst defaultGetColorValue = points => points.length;\nconst defaultGetRadiusValue = cell =>\n  cell.filteredPoints ? cell.filteredPoints.length : cell.points.length;\n\nfunction processGeoJSON(step, props, aggregation, {viewport}) {\n  const {data, getPosition, filterData} = props;\n  const geoJSON = getGeoJSON(data, getPosition, filterData);\n  const clusterBuilder = new ClusterBuilder();\n\n  this.setState({geoJSON, clusterBuilder});\n}\n\nfunction getClusters(step, props, aggregation, {viewport}) {\n  const {geoJSON, clusterBuilder} = this.state;\n  const {clusterRadius, zoom, width, height} = props;\n  const {longitude, latitude} = viewport;\n\n  // zoom needs to be an integer for the different map utils. Also helps with cache key.\n  const bbox = geoViewport.bounds([longitude, latitude], zoom, [width, height]);\n  const clusters = clusterBuilder.clustersAtZoom({bbox, clusterRadius, geoJSON, zoom});\n\n  this.setState({\n    layerData: {data: clusters}\n  });\n}\n\nfunction getSubLayerRadius(dimensionState, dimension, layerProps) {\n  return cell => {\n    const {getRadiusValue} = layerProps;\n    const {scaleFunc} = dimensionState;\n    return scaleFunc(getRadiusValue(cell));\n  };\n}\n\nexport const clusterAggregation = {\n  key: 'position',\n  updateSteps: [\n    {\n      key: 'geojson',\n      triggers: {\n        position: {\n          prop: 'getPosition',\n          updateTrigger: 'getPosition'\n        },\n        filterData: {\n          prop: 'filterData',\n          updateTrigger: 'filterData'\n        }\n      },\n      updater: processGeoJSON\n    },\n    {\n      key: 'clustering',\n      triggers: {\n        clusterRadius: {\n          prop: 'clusterRadius'\n        },\n        zoom: {\n          prop: 'zoom'\n        },\n        width: {\n          prop: 'width'\n        },\n        height: {\n          prop: 'height'\n        }\n      },\n      updater: getClusters\n    }\n  ]\n};\n\nfunction getRadiusValueDomain(step, props, dimensionUpdater) {\n  const {key} = dimensionUpdater;\n  const {getRadiusValue} = props;\n  const {layerData} = this.state;\n\n  const valueDomain = [0, max(layerData.data, getRadiusValue)];\n  this._setDimensionState(key, {valueDomain});\n}\n\nconst clusterLayerDimensions = [\n  defaultColorDimension,\n  {\n    key: 'radius',\n    accessor: 'getRadius',\n    nullValue: 0,\n    updateSteps: [\n      {\n        key: 'getDomain',\n        triggers: {\n          value: {\n            prop: 'getRadiusValue',\n            updateTrigger: 'getRadiusValue'\n          }\n        },\n        updater: getRadiusValueDomain\n      },\n      {\n        key: 'getScaleFunc',\n        triggers: {\n          domain: {prop: 'radiusDomain'},\n          range: {prop: 'radiusRange'},\n          scaleType: {prop: 'radiusScaleType'}\n        },\n        updater: getDimensionScale\n      }\n    ],\n    getSubLayerAccessor: getSubLayerRadius,\n    getPickingInfo: (dimensionState, cell, layerProps) => {\n      const radiusValue = layerProps.getRadiusValue(cell);\n      return {radiusValue};\n    }\n  }\n];\n\nconst defaultProps = {\n  clusterRadius: defaultRadius,\n  colorDomain: null,\n  colorRange: DEFAULT_COLOR_RANGE,\n  colorScaleType: SCALE_TYPES.quantize,\n  radiusScaleType: SCALE_TYPES.sqrt,\n  radiusRange: defaultRadiusRange,\n  getPosition: {type: 'accessor', value: x => x.position},\n  getColorValue: {type: 'accessor', value: defaultGetColorValue},\n  getRadiusValue: {type: 'accessor', value: defaultGetRadiusValue}\n};\n\nexport default class ClusterLayer extends AggregationLayer {\n  initializeState() {\n    const cpuAggregator = new CPUAggregator({\n      aggregation: clusterAggregation,\n      dimensions: clusterLayerDimensions\n    });\n\n    this.state = {\n      cpuAggregator,\n      aggregatorState: cpuAggregator.state\n    };\n    const attributeManager = this.getAttributeManager();\n    attributeManager.add({\n      positions: {size: 3, accessor: 'getPosition'}\n    });\n  }\n\n  updateState({oldProps, props, changeFlags}) {\n    this.setState({\n      // make a copy of the internal state of cpuAggregator for testing\n      aggregatorState: this.state.cpuAggregator.updateState(\n        {oldProps, props, changeFlags},\n        {\n          viewport: this.context.viewport,\n          attributes: this.getAttributes(),\n          numInstances: this.getNumInstances(props)\n        }\n      )\n    });\n  }\n\n  getPickingInfo({info}) {\n    return this.state.cpuAggregator.getPickingInfo({info}, this.props);\n  }\n\n  _getSublayerUpdateTriggers() {\n    return this.state.cpuAggregator.getUpdateTriggers(this.props);\n  }\n\n  _getSubLayerAccessors() {\n    return {\n      getRadius: this.state.cpuAggregator.getAccessor('radius', this.props),\n      getFillColor: this.state.cpuAggregator.getAccessor('fillColor', this.props)\n    };\n  }\n\n  renderLayers() {\n    // for subclassing, override this method to return\n    // customized sub layer props\n    const {id, radiusScale} = this.props;\n    const {cpuAggregator} = this.state;\n\n    // base layer props\n    const {visible, opacity, pickable, autoHighlight, highlightColor} = this.props;\n    const updateTriggers = this._getSublayerUpdateTriggers();\n    const accessors = this._getSubLayerAccessors();\n\n    const distanceScale = getDistanceScales(this.context.viewport);\n    const metersPerPixel = distanceScale.metersPerPixel[0];\n\n    // return props to the sublayer constructor\n    return new ScatterplotLayer({\n      id: `${id}-cluster`,\n      data: cpuAggregator.state.layerData.data,\n      radiusScale: metersPerPixel * radiusScale,\n      visible,\n      opacity,\n      pickable,\n      autoHighlight,\n      highlightColor,\n      updateTriggers,\n      ...accessors\n    });\n  }\n}\n\nClusterLayer.layerName = 'ClusterLayer';\nClusterLayer.defaultProps = defaultProps;\n"]}