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
JavaScript
;
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"]}