UNPKG

kepler.gl

Version:

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

172 lines (134 loc) 16 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.hexagonVisConfigs = undefined; var _extends2 = require('babel-runtime/helpers/extends'); var _extends3 = _interopRequireDefault(_extends2); var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray'); var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2); var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck'); var _classCallCheck3 = _interopRequireDefault(_classCallCheck2); var _createClass2 = require('babel-runtime/helpers/createClass'); var _createClass3 = _interopRequireDefault(_createClass2); var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn'); var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2); var _inherits2 = require('babel-runtime/helpers/inherits'); var _inherits3 = _interopRequireDefault(_inherits2); var _deck = require('deck.gl'); var _aggregationLayer = require('../aggregation-layer'); var _aggregationLayer2 = _interopRequireDefault(_aggregationLayer); var _enhancedHexagonLayer = require('../../deckgl-layers/hexagon-layer/enhanced-hexagon-layer'); var _enhancedHexagonLayer2 = _interopRequireDefault(_enhancedHexagonLayer); var _hexagonUtils = require('./hexagon-utils'); var _hexagonLayerIcon = require('./hexagon-layer-icon'); var _hexagonLayerIcon2 = _interopRequireDefault(_hexagonLayerIcon); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var hexagonVisConfigs = exports.hexagonVisConfigs = { opacity: 'opacity', worldUnitSize: 'worldUnitSize', resolution: 'resolution', colorRange: 'colorRange', coverage: 'coverage', sizeRange: 'elevationRange', percentile: 'percentile', elevationPercentile: 'elevationPercentile', elevationScale: 'elevationScale', 'hi-precision': 'hi-precision', colorAggregation: 'aggregation', sizeAggregation: 'sizeAggregation', enable3d: 'enable3d' }; // Copyright (c) 2018 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. var HexagonLayer = function (_AggregationLayer) { (0, _inherits3.default)(HexagonLayer, _AggregationLayer); function HexagonLayer(props) { (0, _classCallCheck3.default)(this, HexagonLayer); var _this = (0, _possibleConstructorReturn3.default)(this, (HexagonLayer.__proto__ || Object.getPrototypeOf(HexagonLayer)).call(this, props)); _this.registerVisConfig(hexagonVisConfigs); _this.visConfigSettings.worldUnitSize.label = 'Hexagon Radius (km)'; return _this; } (0, _createClass3.default)(HexagonLayer, [{ 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; var zoomFactor = this.getZoomFactor(mapState); var eleZoomFactor = this.getElevationZoomFactor(mapState); var visConfig = this.config.visConfig; var radius = visConfig.worldUnitSize * 1000; return [new _enhancedHexagonLayer2.default((0, _extends3.default)({}, data, { id: this.id, idx: idx, // highlight autoHighlight: visConfig.enable3d, radius: radius, coverage: visConfig.coverage, // color colorRange: this.getColorRange(visConfig.colorRange), colorScale: this.config.colorScale, opacity: visConfig.opacity, upperPercentile: visConfig.percentile[1], lowerPercentile: visConfig.percentile[0], // parameters parameters: { depthTest: Boolean(visConfig.enable3d || mapState.dragRotate) }, // elevation extruded: visConfig.enable3d, elevationScale: visConfig.elevationScale * eleZoomFactor, elevationLowerPercentile: visConfig.elevationPercentile[0], elevationUpperPercentile: visConfig.elevationPercentile[1], // render fp64: visConfig['hi-precision'], pickable: true, lightSettings: this.meta.lightSettings, // callbacks onSetColorDomain: layerCallbacks.onSetLayerDomain }))].concat((0, _toConsumableArray3.default)(this.isLayerHovered(objectHovered) && !visConfig.enable3d ? [new _deck.GeoJsonLayer({ id: this.id + '-hovered', data: [(0, _hexagonUtils.hexagonToPolygonGeo)(objectHovered, {}, radius * visConfig.coverage, mapState)], getLineColor: this.config.highlightColor, lineWidthScale: 8 * zoomFactor })] : [])); } }, { key: 'type', get: function get() { return 'hexagon'; } }, { key: 'name', get: function get() { return 'Hexbin'; } }, { key: 'layerIcon', get: function get() { return _hexagonLayerIcon2.default; } }]); return HexagonLayer; }(_aggregationLayer2.default); exports.default = HexagonLayer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/hexagon-layer/hexagon-layer.js"],"names":["hexagonVisConfigs","opacity","worldUnitSize","resolution","colorRange","coverage","sizeRange","percentile","elevationPercentile","elevationScale","colorAggregation","sizeAggregation","enable3d","HexagonLayer","props","registerVisConfig","visConfigSettings","label","data","idx","objectHovered","mapState","interaction","layerCallbacks","zoomFactor","getZoomFactor","eleZoomFactor","getElevationZoomFactor","visConfig","config","radius","EnhancedHexagonLayer","id","autoHighlight","getColorRange","colorScale","upperPercentile","lowerPercentile","parameters","depthTest","Boolean","dragRotate","extruded","elevationLowerPercentile","elevationUpperPercentile","fp64","pickable","lightSettings","meta","onSetColorDomain","onSetLayerDomain","isLayerHovered","GeoJsonLayer","getLineColor","highlightColor","lineWidthScale","HexagonLayerIcon","AggregationLayer"],"mappings":"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","file":"hexagon-layer.js","sourcesContent":["// Copyright (c) 2018 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} from 'deck.gl';\nimport AggregationLayer from '../aggregation-layer';\nimport EnhancedHexagonLayer from 'deckgl-layers/hexagon-layer/enhanced-hexagon-layer';\nimport {hexagonToPolygonGeo} from './hexagon-utils';\nimport HexagonLayerIcon from './hexagon-layer-icon';\n\nexport const hexagonVisConfigs = {\n  opacity: 'opacity',\n  worldUnitSize: 'worldUnitSize',\n  resolution: 'resolution',\n  colorRange: 'colorRange',\n  coverage: 'coverage',\n  sizeRange: 'elevationRange',\n  percentile: 'percentile',\n  elevationPercentile: 'elevationPercentile',\n  elevationScale: 'elevationScale',\n  'hi-precision': 'hi-precision',\n  colorAggregation: 'aggregation',\n  sizeAggregation: 'sizeAggregation',\n  enable3d: 'enable3d'\n};\n\nexport default class HexagonLayer extends AggregationLayer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(hexagonVisConfigs);\n    this.visConfigSettings.worldUnitSize.label = 'Hexagon Radius (km)';\n  }\n\n  get type() {\n    return 'hexagon';\n  }\n\n  get name() {\n    return 'Hexbin';\n  }\n\n  get layerIcon() {\n    return HexagonLayerIcon;\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    mapState,\n    interaction,\n    layerCallbacks\n  }) {\n    const zoomFactor = this.getZoomFactor(mapState);\n    const eleZoomFactor = this.getElevationZoomFactor(mapState);\n    const {visConfig} = this.config;\n    const radius = visConfig.worldUnitSize * 1000;\n\n    return [\n      new EnhancedHexagonLayer({\n        ...data,\n        id: this.id,\n        idx,\n\n        // highlight\n        autoHighlight: visConfig.enable3d,\n\n        radius,\n        coverage: visConfig.coverage,\n\n        // color\n        colorRange: this.getColorRange(visConfig.colorRange),\n        colorScale: this.config.colorScale,\n        opacity: visConfig.opacity,\n        upperPercentile: visConfig.percentile[1],\n        lowerPercentile: visConfig.percentile[0],\n\n        // parameters\n        parameters: {depthTest: Boolean(visConfig.enable3d || mapState.dragRotate)},\n\n        // elevation\n        extruded: visConfig.enable3d,\n        elevationScale: visConfig.elevationScale * eleZoomFactor,\n        elevationLowerPercentile: visConfig.elevationPercentile[0],\n        elevationUpperPercentile: visConfig.elevationPercentile[1],\n\n        // render\n        fp64: visConfig['hi-precision'],\n        pickable: true,\n        lightSettings: this.meta.lightSettings,\n        // callbacks\n        onSetColorDomain: layerCallbacks.onSetLayerDomain\n      }),\n\n      // render an outline of each hexagon if not extruded\n      ...(this.isLayerHovered(objectHovered) && !visConfig.enable3d\n        ? [\n            new GeoJsonLayer({\n              id: `${this.id}-hovered`,\n              data: [\n                hexagonToPolygonGeo(\n                  objectHovered,\n                  {},\n                  radius * visConfig.coverage,\n                  mapState\n                )\n              ],\n              getLineColor: this.config.highlightColor,\n              lineWidthScale: 8 * zoomFactor\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}