UNPKG

kepler.gl.geoiq

Version:

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

256 lines (214 loc) 25.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.scenegraphVisConfigs = exports.scenegraphRequiredColumns = exports.scenegraphPosResolver = exports.scenegraphPosAccessor = exports.scenegraphOptionalColumns = exports["default"] = 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 _meshLayers = require("@deck.gl/mesh-layers"); var _core = require("@loaders.gl/core"); var _addons = require("@luma.gl/addons"); var _baseLayer = _interopRequireDefault(require("../base-layer")); var _lodash = _interopRequireDefault(require("lodash.memoize")); var _scenegraphLayerIcon = _interopRequireDefault(require("./scenegraph-layer-icon")); var _scenegraphInfoModal = _interopRequireDefault(require("./scenegraph-info-modal")); 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 scenegraphRequiredColumns = exports.scenegraphRequiredColumns = ['lat', 'lng']; var scenegraphOptionalColumns = exports.scenegraphOptionalColumns = ['altitude']; function fetch(url, _ref) { var propName = _ref.propName, layer = _ref.layer; if (propName === 'scenegraph') { return (0, _core.load)(url, _addons.GLTFScenegraphLoader, layer.getLoadOptions()); } return fetch(url).then(function (response) { return response.json(); }); } var scenegraphPosAccessor = exports.scenegraphPosAccessor = function scenegraphPosAccessor(_ref2) { var lat = _ref2.lat, lng = _ref2.lng, altitude = _ref2.altitude; return function (d) { return [// lng d.data[lng.fieldIdx], // lat d.data[lat.fieldIdx], // altitude altitude && altitude.fieldIdx > -1 ? d.data[altitude.fieldIdx] : 0]; }; }; var scenegraphPosResolver = exports.scenegraphPosResolver = function scenegraphPosResolver(_ref3) { var lat = _ref3.lat, lng = _ref3.lng, altitude = _ref3.altitude; return "".concat(lat.fieldIdx, "-").concat(lng.fieldIdx, "-").concat(altitude ? altitude.fieldIdx : 'z'); }; var scenegraphVisConfigs = exports.scenegraphVisConfigs = { opacity: 'opacity', colorRange: 'colorRange', // sizeScale: 'sizeScale', angleX: 'angleX', angleY: 'angleY', angleZ: 'angleZ' }; var DEFAULT_MODEL = 'https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/Duck/glTF-Binary/Duck.glb'; var DEFAULT_TRANSITION = [0, 0, 0]; var DEFAULT_SCALE = [1, 1, 1]; var DEFAULT_COLOR = [255, 255, 255, 255]; var ScenegraphLayer = exports["default"] = /*#__PURE__*/function (_Layer) { (0, _inherits2["default"])(ScenegraphLayer, _Layer); var _super = _createSuper(ScenegraphLayer); function ScenegraphLayer(props) { var _this; (0, _classCallCheck2["default"])(this, ScenegraphLayer); _this = _super.call(this, props); _this.registerVisConfig(scenegraphVisConfigs); _this.getPosition = (0, _lodash["default"])(scenegraphPosAccessor, scenegraphPosResolver); // prepare layer info modal _this._layerInfoModal = (0, _scenegraphInfoModal["default"])(); return _this; } (0, _createClass2["default"])(ScenegraphLayer, [{ key: "type", get: function get() { return '3D'; } }, { key: "requiredLayerColumns", get: function get() { return scenegraphRequiredColumns; } }, { key: "optionalColumns", get: function get() { return scenegraphOptionalColumns; } }, { key: "columnPairs", get: function get() { return this.defaultPointColumnPairs; } }, { key: "layerIcon", get: function get() { return _scenegraphLayerIcon["default"]; } }, { key: "layerInfoModal", get: function get() { return { id: 'scenegraphInfo', template: this._layerInfoModal, modalProps: { title: 'How to use Scenegraph' } }; } }, { key: "formatLayerData", value: function formatLayerData(_, allData, filteredIndex, oldLayerData) { var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {}; var columns = this.config.columns; var getPosition = this.getPosition(columns); if (!oldLayerData || oldLayerData.getPosition !== getPosition) { this.updateLayerMeta(allData, getPosition); } var data; if (oldLayerData && oldLayerData.data && opt.sameData && oldLayerData.getPosition === getPosition) { data = oldLayerData.data; } else { data = filteredIndex.reduce(function (accu, index) { var pos = getPosition({ data: allData[index] }); // if doesn't have point lat or lng, do not add the point // deck.gl can't handle position = null if (!pos.every(Number.isFinite)) { return accu; } accu.push({ index: index, data: allData[index] }); return accu; }, []); } return { data: data, getPosition: getPosition }; } }, { key: "updateLayerMeta", value: function updateLayerMeta(allData, getPosition) { var bounds = this.getPointsBounds(allData, function (d) { return getPosition({ data: d }); }); this.updateMeta({ bounds: bounds }); } }, { key: "renderLayer", value: function renderLayer(_ref4) { var data = _ref4.data, idx = _ref4.idx, objectHovered = _ref4.objectHovered, mapState = _ref4.mapState, interactionConfig = _ref4.interactionConfig, layerInteraction = _ref4.layerInteraction; var layerProps = _objectSpread({ radiusMinPixels: 1, radiusScale: this.getRadiusScaleByZoom(mapState) }, this.config.visConfig.fixedRadius ? {} : { radiusMaxPixels: 500 }); var _this$config$visConfi = this.config.visConfig, _this$config$visConfi2 = _this$config$visConfi.sizeScale, sizeScale = _this$config$visConfi2 === void 0 ? 1 : _this$config$visConfi2, _this$config$visConfi3 = _this$config$visConfi.angleX, angleX = _this$config$visConfi3 === void 0 ? 0 : _this$config$visConfi3, _this$config$visConfi4 = _this$config$visConfi.angleY, angleY = _this$config$visConfi4 === void 0 ? 0 : _this$config$visConfi4, _this$config$visConfi5 = _this$config$visConfi.angleZ, angleZ = _this$config$visConfi5 === void 0 ? 90 : _this$config$visConfi5; return [new _meshLayers.ScenegraphLayer(_objectSpread(_objectSpread(_objectSpread(_objectSpread({}, layerProps), data), layerInteraction), {}, { id: this.id, idx: idx, opacity: this.config.visConfig.opacity, fetch: fetch, scenegraph: this.config.visConfig.scenegraph || DEFAULT_MODEL, sizeScale: sizeScale, getTranslation: DEFAULT_TRANSITION, getScale: DEFAULT_SCALE, getOrientation: [angleX, angleY, angleZ], getColor: DEFAULT_COLOR, // picking pickable: true, // parameters parameters: { depthTest: true, blend: false }, // update triggers updateTriggers: { getOrientation: { angleX: angleX, angleY: angleY, angleZ: angleZ } } }))]; } }]); return ScenegraphLayer; }(_baseLayer["default"]); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/scenegraph-layer/scenegraph-layer.js"],"names":["scenegraphRequiredColumns","scenegraphOptionalColumns","fetch","url","propName","layer","GLTFScenegraphLoader","getLoadOptions","then","response","json","scenegraphPosAccessor","lat","lng","altitude","d","data","fieldIdx","scenegraphPosResolver","scenegraphVisConfigs","opacity","colorRange","sizeScale","angleX","angleY","angleZ","DEFAULT_MODEL","DEFAULT_TRANSITION","DEFAULT_SCALE","DEFAULT_COLOR","ScenegraphLayer","props","registerVisConfig","getPosition","_layerInfoModal","defaultPointColumnPairs","ScenegraphLayerIcon","id","template","modalProps","title","_","allData","filteredIndex","oldLayerData","opt","columns","config","updateLayerMeta","sameData","reduce","accu","index","pos","every","Number","isFinite","push","bounds","getPointsBounds","updateMeta","idx","objectHovered","mapState","interactionConfig","layerInteraction","layerProps","radiusMinPixels","radiusScale","getRadiusScaleByZoom","visConfig","fixedRadius","radiusMaxPixels","DeckScenegraphLayer","scenegraph","getTranslation","getScale","getOrientation","getColor","pickable","parameters","depthTest","blend","updateTriggers","Layer"],"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 {ScenegraphLayer as DeckScenegraphLayer} from '@deck.gl/mesh-layers';\nimport {load} from '@loaders.gl/core';\nimport {GLTFScenegraphLoader} from '@luma.gl/addons';\n\nimport Layer from '../base-layer';\nimport memoize from 'lodash.memoize';\nimport ScenegraphLayerIcon from './scenegraph-layer-icon';\nimport ScenegraphInfoModalFactory from './scenegraph-info-modal';\n\nexport const scenegraphRequiredColumns = ['lat', 'lng'];\nexport const scenegraphOptionalColumns = ['altitude'];\n\nfunction fetch(url, {propName, layer}) {\n  if (propName === 'scenegraph') {\n    return load(url, GLTFScenegraphLoader, layer.getLoadOptions());\n  }\n\n  return fetch(url).then(response => response.json());\n}\n\nexport const scenegraphPosAccessor = ({lat, lng, altitude}) => d => [\n  // lng\n  d.data[lng.fieldIdx],\n  // lat\n  d.data[lat.fieldIdx],\n  // altitude\n  altitude && altitude.fieldIdx > -1 ? d.data[altitude.fieldIdx] : 0\n];\n\nexport const scenegraphPosResolver = ({lat, lng, altitude}) =>\n  `${lat.fieldIdx}-${lng.fieldIdx}-${altitude ? altitude.fieldIdx : 'z'}`;\n\nexport const scenegraphVisConfigs = {\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  //\n  sizeScale: 'sizeScale',\n  angleX: 'angleX',\n  angleY: 'angleY',\n  angleZ: 'angleZ'\n};\n\nconst DEFAULT_MODEL =\n  'https://raw.githubusercontent.com/KhronosGroup/glTF-Sample-Models/master/2.0/Duck/glTF-Binary/Duck.glb';\nconst DEFAULT_TRANSITION = [0, 0, 0];\nconst DEFAULT_SCALE = [1, 1, 1];\nconst DEFAULT_COLOR = [255, 255, 255, 255];\n\nexport default class ScenegraphLayer extends Layer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(scenegraphVisConfigs);\n    this.getPosition = memoize(scenegraphPosAccessor, scenegraphPosResolver);\n\n    // prepare layer info modal\n    this._layerInfoModal = ScenegraphInfoModalFactory();\n  }\n\n  get type() {\n    return '3D';\n  }\n\n  get requiredLayerColumns() {\n    return scenegraphRequiredColumns;\n  }\n\n  get optionalColumns() {\n    return scenegraphOptionalColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultPointColumnPairs;\n  }\n\n  get layerIcon() {\n    return ScenegraphLayerIcon;\n  }\n\n  get layerInfoModal() {\n    return {\n      id: 'scenegraphInfo',\n      template: this._layerInfoModal,\n      modalProps: {\n        title: 'How to use Scenegraph'\n      }\n    };\n  }\n\n  formatLayerData(_, allData, filteredIndex, oldLayerData, opt = {}) {\n    const {columns} = this.config;\n\n    const getPosition = this.getPosition(columns);\n\n    if (!oldLayerData || oldLayerData.getPosition !== getPosition) {\n      this.updateLayerMeta(allData, getPosition);\n    }\n\n    let data;\n    if (\n      oldLayerData &&\n      oldLayerData.data &&\n      opt.sameData &&\n      oldLayerData.getPosition === getPosition\n    ) {\n      data = oldLayerData.data;\n    } else {\n      data = filteredIndex.reduce((accu, index) => {\n        const pos = getPosition({data: allData[index]});\n\n        // if doesn't have point lat or lng, do not add the point\n        // deck.gl can't handle position = null\n        if (!pos.every(Number.isFinite)) {\n          return accu;\n        }\n\n        accu.push({\n          index,\n          data: allData[index]\n        });\n\n        return accu;\n      }, []);\n    }\n\n    return {\n      data,\n      getPosition\n    };\n  }\n\n  updateLayerMeta(allData, getPosition) {\n    const bounds = this.getPointsBounds(allData, d => getPosition({data: d}));\n    this.updateMeta({bounds});\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    mapState,\n    interactionConfig,\n    layerInteraction\n  }) {\n    const layerProps = {\n      radiusMinPixels: 1,\n      radiusScale: this.getRadiusScaleByZoom(mapState),\n      ...(this.config.visConfig.fixedRadius ? {} : {radiusMaxPixels: 500})\n    };\n\n    const {\n      visConfig: {sizeScale = 1, angleX = 0, angleY = 0, angleZ = 90}\n    } = this.config;\n\n    return [\n      new DeckScenegraphLayer({\n        ...layerProps,\n        ...data,\n        ...layerInteraction,\n        id: this.id,\n        idx,\n        opacity: this.config.visConfig.opacity,\n\n        fetch,\n\n        scenegraph: this.config.visConfig.scenegraph || DEFAULT_MODEL,\n\n        sizeScale,\n        getTranslation: DEFAULT_TRANSITION,\n        getScale: DEFAULT_SCALE,\n        getOrientation: [angleX, angleY, angleZ],\n        getColor: DEFAULT_COLOR,\n\n        // picking\n        pickable: true,\n\n        // parameters\n        parameters: {depthTest: true, blend: false},\n\n        // update triggers\n        updateTriggers: {\n          getOrientation: {angleX, angleY, angleZ}\n        }\n      })\n    ];\n  }\n}\n"]}