kepler.gl.geoiq
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
144 lines (116 loc) • 17.1 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.hexagonVisConfigs = exports["default"] = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
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 _deck = require("deck.gl");
var _aggregationLayer = _interopRequireDefault(require("../aggregation-layer"));
var _enhancedHexagonLayer = _interopRequireDefault(require("../../deckgl-layers/hexagon-layer/enhanced-hexagon-layer"));
var _hexagonUtils = require("./hexagon-utils");
var _hexagonLayerIcon = _interopRequireDefault(require("./hexagon-layer-icon"));
var _dataUtils = require("../../utils/data-utils");
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 hexagonVisConfigs = exports.hexagonVisConfigs = {
opacity: 'opacity',
worldUnitSize: 'worldUnitSize',
resolution: 'resolution',
colorRange: 'colorRange',
coverage: 'coverage',
sizeRange: 'elevationRange',
percentile: 'percentile',
elevationPercentile: 'elevationPercentile',
elevationScale: 'elevationScale',
colorAggregation: 'aggregation',
sizeAggregation: 'sizeAggregation',
enable3d: 'enable3d'
};
var HexagonLayer = exports["default"] = /*#__PURE__*/function (_AggregationLayer) {
(0, _inherits2["default"])(HexagonLayer, _AggregationLayer);
var _super = _createSuper(HexagonLayer);
function HexagonLayer(props) {
var _this;
(0, _classCallCheck2["default"])(this, HexagonLayer);
_this = _super.call(this, props);
_this.registerVisConfig(hexagonVisConfigs);
_this.visConfigSettings.worldUnitSize.label = 'Hexagon Radius (km)';
return _this;
}
(0, _createClass2["default"])(HexagonLayer, [{
key: "type",
get: function get() {
return 'hexagon';
}
}, {
key: "name",
get: function get() {
return 'Hexbin';
}
}, {
key: "layerIcon",
get: function get() {
return _hexagonLayerIcon["default"];
}
}, {
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 radius = visConfig.worldUnitSize * 1000;
return [new _enhancedHexagonLayer["default"](_objectSpread(_objectSpread(_objectSpread({}, data), layerInteraction), {}, {
id: this.id,
idx: idx,
// highlight
autoHighlight: visConfig.enable3d,
highlightColor: _defaultSettings.HIGHLIGH_COLOR_3D,
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
pickable: true,
// callbacks
onSetColorDomain: layerCallbacks.onSetLayerDomain
}))].concat((0, _toConsumableArray2["default"])(this.isLayerHovered(objectHovered) && !visConfig.enable3d ? [new _deck.GeoJsonLayer(_objectSpread(_objectSpread({}, layerInteraction), {}, {
id: "".concat(this.id, "-hovered"),
data: [(0, _hexagonUtils.hexagonToPolygonGeo)(objectHovered, {}, radius * visConfig.coverage, mapState)],
getLineColor: this.config.highlightColor,
lineWidthScale: (0, _dataUtils.clamp)([1, 100], radius * 0.1 * zoomFactor)
}))] : []));
}
}]);
return HexagonLayer;
}(_aggregationLayer["default"]);
//# 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","HexagonLayerIcon","data","idx","objectHovered","mapState","interaction","layerCallbacks","layerInteraction","zoomFactor","getZoomFactor","eleZoomFactor","getElevationZoomFactor","visConfig","config","radius","EnhancedHexagonLayer","id","autoHighlight","highlightColor","HIGHLIGH_COLOR_3D","getColorRange","colorScale","upperPercentile","lowerPercentile","parameters","depthTest","Boolean","dragRotate","extruded","elevationLowerPercentile","elevationUpperPercentile","pickable","onSetColorDomain","onSetLayerDomain","isLayerHovered","GeoJsonLayer","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} 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';\nimport {clamp} from 'utils/data-utils';\nimport {HIGHLIGH_COLOR_3D} from 'constants/default-settings';\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  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    layerInteraction\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        ...layerInteraction,\n        id: this.id,\n        idx,\n\n        // highlight\n        autoHighlight: visConfig.enable3d,\n        highlightColor: HIGHLIGH_COLOR_3D,\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        pickable: true,\n\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              ...layerInteraction,\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: clamp([1, 100], radius * 0.1 * zoomFactor)\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}