UNPKG

kepler.gl.geoiq

Version:

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

167 lines (137 loc) 20 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.gridVisConfigs = exports["default"] = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); 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 _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); 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 _deck = require("deck.gl"); var _aggregationLayer = _interopRequireDefault(require("../aggregation-layer")); var _enhancedCpuGridLayer = _interopRequireDefault(require("../../deckgl-layers/grid-layer/enhanced-cpu-grid-layer")); var _gridUtils = require("./grid-utils"); var _gridLayerIcon = _interopRequireDefault(require("./grid-layer-icon")); var _defaultSettings = require("../../constants/default-settings"); 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 _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 gridVisConfigs = exports.gridVisConfigs = { opacity: 'opacity', worldUnitSize: 'worldUnitSize', colorRange: 'colorRange', coverage: 'coverage', sizeRange: 'elevationRange', percentile: 'percentile', elevationPercentile: 'elevationPercentile', elevationScale: 'elevationScale', colorAggregation: 'aggregation', sizeAggregation: 'sizeAggregation', enable3d: 'enable3d' }; var GridLayer = exports["default"] = /*#__PURE__*/function (_AggregationLayer) { (0, _inherits2["default"])(GridLayer, _AggregationLayer); var _super = _createSuper(GridLayer); function GridLayer(props) { var _this; (0, _classCallCheck2["default"])(this, GridLayer); _this = _super.call(this, props); _this.registerVisConfig(gridVisConfigs); _this.visConfigSettings.worldUnitSize.label = 'Grid Size (km)'; return _this; } (0, _createClass2["default"])(GridLayer, [{ key: "type", get: function get() { return 'grid'; } }, { key: "layerIcon", get: function get() { return _gridLayerIcon["default"]; } }, { key: "formatLayerData", value: function formatLayerData(_, allData, filteredIndex, oldLayerData) { var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {}; var formattedData = (0, _get2["default"])((0, _getPrototypeOf2["default"])(GridLayer.prototype), "formatLayerData", this).call(this, _, allData, filteredIndex, oldLayerData, opt); var getPosition = formattedData.getPosition, data = formattedData.data; // TODO: fix this in deck.gl layer var cleaned = data.filter(function (d) { var pos = getPosition(d); return pos.every(Number.isFinite); }); // All data processing is done in deck.gl layer return _objectSpread(_objectSpread({}, formattedData), {}, { data: cleaned }); } }, { key: "renderLayer", value: function renderLayer(_ref) { var data = _ref.data, idx = _ref.idx, objectHovered = _ref.objectHovered, mapState = _ref.mapState, interaction = _ref.interaction, layerCallbacks = _ref.layerCallbacks, layerInteraction = _ref.layerInteraction; var zoomFactor = this.getZoomFactor(mapState); var eleZoomFactor = this.getElevationZoomFactor(mapState); var visConfig = this.config.visConfig; var cellSize = visConfig.worldUnitSize * 1000; return [new _deck.GridLayer(_objectSpread(_objectSpread(_objectSpread({}, data), layerInteraction), {}, { id: this.id, idx: idx, cellSize: cellSize, coverage: visConfig.coverage, // highlight autoHighlight: visConfig.enable3d, highlightColor: _defaultSettings.HIGHLIGH_COLOR_3D, // color colorRange: this.getColorRange(visConfig.colorRange), colorScale: this.config.colorScale, sizeScale: this.config.sizeScale, opacity: visConfig.opacity, upperPercentile: visConfig.percentile[1], lowerPercentile: visConfig.percentile[0], // elevation extruded: visConfig.enable3d, elevationScale: visConfig.elevationScale * eleZoomFactor, elevationRange: visConfig.sizeRange, elevationLowerPercentile: visConfig.elevationPercentile[0], elevationUpperPercentile: visConfig.elevationPercentile[1], // parameters parameters: { depthTest: Boolean(visConfig.enable3d || mapState.dragRotate) }, // render pickable: true, // callbacks onSetColorDomain: layerCallbacks.onSetLayerDomain, _subLayerProps: { CPU: { type: _enhancedCpuGridLayer["default"] } } }))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) && !visConfig.enable3d ? [new _deck.GeoJsonLayer(_objectSpread(_objectSpread({}, layerInteraction), {}, { id: "".concat(this.id, "-hovered"), data: [(0, _gridUtils.pointToPolygonGeo)({ object: objectHovered.object, cellSize: cellSize, coverage: visConfig.coverage, mapState: mapState })], getLineColor: this.config.highlightColor, lineWidthScale: 8 * zoomFactor }))] : [])); } }]); return GridLayer; }(_aggregationLayer["default"]); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/grid-layer/grid-layer.js"],"names":["gridVisConfigs","opacity","worldUnitSize","colorRange","coverage","sizeRange","percentile","elevationPercentile","elevationScale","colorAggregation","sizeAggregation","enable3d","GridLayer","props","registerVisConfig","visConfigSettings","label","GridLayerIcon","_","allData","filteredIndex","oldLayerData","opt","formattedData","getPosition","data","cleaned","filter","d","pos","every","Number","isFinite","idx","objectHovered","mapState","interaction","layerCallbacks","layerInteraction","zoomFactor","getZoomFactor","eleZoomFactor","getElevationZoomFactor","visConfig","config","cellSize","DeckGLGridLayer","id","autoHighlight","highlightColor","HIGHLIGH_COLOR_3D","getColorRange","colorScale","sizeScale","upperPercentile","lowerPercentile","extruded","elevationRange","elevationLowerPercentile","elevationUpperPercentile","parameters","depthTest","Boolean","dragRotate","pickable","onSetColorDomain","onSetLayerDomain","_subLayerProps","CPU","type","EnhancedCPUGridLayer","isLayerHovered","GeoJsonLayer","object","getLineColor","lineWidthScale","AggregationLayer"],"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 {GeoJsonLayer, GridLayer as DeckGLGridLayer} from 'deck.gl';\nimport AggregationLayer from '../aggregation-layer';\nimport EnhancedCPUGridLayer from 'deckgl-layers/grid-layer/enhanced-cpu-grid-layer';\nimport {pointToPolygonGeo} from './grid-utils';\nimport GridLayerIcon from './grid-layer-icon';\nimport {HIGHLIGH_COLOR_3D} from 'constants/default-settings';\n\nexport const gridVisConfigs = {\n  opacity: 'opacity',\n  worldUnitSize: 'worldUnitSize',\n  colorRange: 'colorRange',\n  coverage: 'coverage',\n  sizeRange: 'elevationRange',\n  percentile: 'percentile',\n  elevationPercentile: 'elevationPercentile',\n  elevationScale: 'elevationScale',\n  colorAggregation: 'aggregation',\n  sizeAggregation: 'sizeAggregation',\n  enable3d: 'enable3d'\n};\n\nexport default class GridLayer extends AggregationLayer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(gridVisConfigs);\n    this.visConfigSettings.worldUnitSize.label = 'Grid Size (km)';\n  }\n\n  get type() {\n    return 'grid';\n  }\n\n  get layerIcon() {\n    return GridLayerIcon;\n  }\n\n  formatLayerData(_, allData, filteredIndex, oldLayerData, opt = {}) {\n    const formattedData = super.formatLayerData(\n      _,\n      allData,\n      filteredIndex,\n      oldLayerData,\n      opt\n    );\n\n    const {getPosition, data} = formattedData;\n\n    // TODO: fix this in deck.gl layer\n    const cleaned = data.filter(d => {\n      const pos = getPosition(d);\n      return pos.every(Number.isFinite);\n    });\n\n    // All data processing is done in deck.gl layer\n    return {\n      ...formattedData,\n      data: cleaned\n    };\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    mapState,\n    interaction,\n    layerCallbacks,\n    layerInteraction\n  }) {\n    const zoomFactor = this.getZoomFactor(mapState);\n    const eleZoomFactor = this.getElevationZoomFactor(mapState);\n    const {visConfig} = this.config;\n    const cellSize = visConfig.worldUnitSize * 1000;\n\n    return [\n      new DeckGLGridLayer({\n        ...data,\n        ...layerInteraction,\n        id: this.id,\n        idx,\n        cellSize,\n        coverage: visConfig.coverage,\n        // highlight\n        autoHighlight: visConfig.enable3d,\n        highlightColor: HIGHLIGH_COLOR_3D,\n\n        // color\n        colorRange: this.getColorRange(visConfig.colorRange),\n        colorScale: this.config.colorScale,\n        sizeScale: this.config.sizeScale,\n        opacity: visConfig.opacity,\n        upperPercentile: visConfig.percentile[1],\n        lowerPercentile: visConfig.percentile[0],\n\n        // elevation\n        extruded: visConfig.enable3d,\n        elevationScale: visConfig.elevationScale * eleZoomFactor,\n        elevationRange: visConfig.sizeRange,\n        elevationLowerPercentile: visConfig.elevationPercentile[0],\n        elevationUpperPercentile: visConfig.elevationPercentile[1],\n        // parameters\n        parameters: {depthTest: Boolean(visConfig.enable3d || mapState.dragRotate)},\n\n        // render\n        pickable: true,\n\n        // callbacks\n        onSetColorDomain: layerCallbacks.onSetLayerDomain,\n\n        _subLayerProps: {\n          CPU: {\n            type: EnhancedCPUGridLayer\n          }\n        }\n      }),\n\n      // render an outline of each cell if not extruded\n      ...(this.isLayerHovered(objectHovered) && !visConfig.enable3d\n        ? [\n            new GeoJsonLayer({\n              ...layerInteraction,\n              id: `${this.id}-hovered`,\n              data: [\n                pointToPolygonGeo({\n                  object: objectHovered.object,\n                  cellSize,\n                  coverage: visConfig.coverage,\n                  mapState\n                })\n              ],\n              getLineColor: this.config.highlightColor,\n              lineWidthScale: 8 * zoomFactor\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}