kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
307 lines (300 loc) • 39 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
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 _constants = require("@kepler.gl/constants");
var _clusterUtils = _interopRequireWildcard(require("../layer-utils/cluster-utils"));
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
var defaultRadius = _constants.LAYER_VIS_CONFIGS.clusterRadius.defaultValue;
var defaultRadiusRange = _constants.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;
};
// eslint-disable-next-line @typescript-eslint/no-unused-vars
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
});
}
// eslint-disable-next-line @typescript-eslint/no-unused-vars
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 = exports.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
}]
};
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);
var scaleFunc = dimensionState.scaleFunc;
var scaledRadiusValue = scaleFunc ? scaleFunc(radiusValue) : radiusValue;
return {
radiusValue: radiusValue,
scaledRadiusValue: scaledRadiusValue
};
}
}];
var defaultProps = {
clusterRadius: defaultRadius,
colorDomain: null,
colorRange: _constants.DEFAULT_COLOR_RANGE,
colorScaleType: _constants.SCALE_TYPES.quantize,
radiusScaleType: _constants.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 = exports["default"] = /*#__PURE__*/function (_AggregationLayer) {
function ClusterLayer() {
(0, _classCallCheck2["default"])(this, ClusterLayer);
return _callSuper(this, ClusterLayer, arguments);
}
(0, _inherits2["default"])(ClusterLayer, _AggregationLayer);
return (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;
var obj = this.state.cpuAggregator.getPickingInfo({
info: info
}, this.props);
if (obj !== null && obj !== void 0 && obj.object) {
// @ts-expect-error
var distanceScale = (0, _viewportMercatorProject.getDistanceScales)(this.context.viewport);
var metersPerPixel = distanceScale.metersPerPixel[0];
obj.object.scaledRadiusValue = obj.object.scaledRadiusValue * metersPerPixel;
}
return obj;
}
}, {
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();
// @ts-expect-error
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,
parameters: {
depthMask: false
}
}, accessors));
}
}]);
}(_aggregationLayers._AggregationLayer);
ClusterLayer.layerName = 'ClusterLayer';
ClusterLayer.defaultProps = defaultProps;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_layers","require","_aggregationLayers","_geoViewport","_interopRequireDefault","_cpuAggregator","_interopRequireWildcard","_viewportMercatorProject","_d3Array","_constants","_clusterUtils","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","defaultRadius","LAYER_VIS_CONFIGS","clusterRadius","defaultValue","defaultRadiusRange","clusterRadiusRange","defaultGetColorValue","points","defaultGetRadiusValue","cell","filteredPoints","processGeoJSON","step","props","aggregation","_ref","viewport","data","getPosition","filterData","geoJSON","getGeoJSON","clusterBuilder","ClusterBuilder","setState","getClusters","_ref2","_this$state","state","zoom","width","height","longitude","latitude","bbox","geoViewport","bounds","clusters","clustersAtZoom","layerData","getSubLayerRadius","dimensionState","dimension","layerProps","getRadiusValue","scaleFunc","clusterAggregation","exports","key","updateSteps","triggers","position","prop","updateTrigger","updater","getRadiusValueDomain","dimensionUpdater","valueDomain","max","_setDimensionState","clusterLayerDimensions","defaultColorDimension","accessor","nullValue","value","domain","range","scaleType","getDimensionScale","getSubLayerAccessor","getPickingInfo","radiusValue","scaledRadiusValue","defaultProps","colorDomain","colorRange","DEFAULT_COLOR_RANGE","colorScaleType","SCALE_TYPES","quantize","radiusScaleType","sqrt","radiusRange","type","x","getColorValue","ClusterLayer","_AggregationLayer","_classCallCheck2","_inherits2","_createClass2","initializeState","cpuAggregator","CPUAggregator","dimensions","aggregatorState","attributeManager","getAttributeManager","add","positions","size","updateState","_ref3","oldProps","changeFlags","context","attributes","getAttributes","numInstances","getNumInstances","_ref4","info","obj","object","distanceScale","getDistanceScales","metersPerPixel","_getSublayerUpdateTriggers","getUpdateTriggers","_getSubLayerAccessors","getRadius","getAccessor","getFillColor","renderLayers","_this$props","id","radiusScale","_this$props2","visible","opacity","pickable","autoHighlight","highlightColor","updateTriggers","accessors","ScatterplotLayer","concat","parameters","depthMask","AggregationLayer","layerName"],"sources":["../../src/cluster-layer/cluster-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\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  AggregationType,\n  defaultColorDimension,\n  DimensionType,\n  getDimensionScale\n} from '../layer-utils/cpu-aggregator';\nimport {getDistanceScales} from 'viewport-mercator-project';\nimport {max} from 'd3-array';\n\nimport {SCALE_TYPES, DEFAULT_COLOR_RANGE, LAYER_VIS_CONFIGS} from '@kepler.gl/constants';\nimport ClusterBuilder, {getGeoJSON} from '../layer-utils/cluster-utils';\nimport {RGBAColor} from '@kepler.gl/types';\nimport {AggregationLayerProps} from '@deck.gl/aggregation-layers/aggregation-layer';\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\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction processGeoJSON(this: CPUAggregator, 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\n// eslint-disable-next-line @typescript-eslint/no-unused-vars\nfunction getClusters(this: CPUAggregator, 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: AggregationType = {\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(this: CPUAggregator, 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: [DimensionType<RGBAColor>, DimensionType<number>] = [\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      const {scaleFunc} = dimensionState;\n      const scaledRadiusValue = scaleFunc ? scaleFunc(radiusValue) : radiusValue;\n\n      return {radiusValue, scaledRadiusValue};\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  any,\n  AggregationLayerProps<any> & {radiusScale: number}\n> {\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    const obj = this.state.cpuAggregator.getPickingInfo({info}, this.props);\n    if (obj?.object) {\n      // @ts-expect-error\n      const distanceScale = getDistanceScales(this.context.viewport);\n      const metersPerPixel = distanceScale.metersPerPixel[0];\n      obj.object.scaledRadiusValue = obj.object.scaledRadiusValue * metersPerPixel;\n    }\n\n    return obj;\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    // @ts-expect-error\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      parameters: {\n        depthMask: false\n      },\n      ...accessors\n    });\n  }\n}\n\nClusterLayer.layerName = 'ClusterLayer';\nClusterLayer.defaultProps = defaultProps;\n"],"mappings":"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","ignoreList":[]}