UNPKG

kepler.gl

Version:

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

95 lines (94 loc) 16.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; 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 _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _get2 = _interopRequireDefault(require("@babel/runtime/helpers/get")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _layers = require("@deck.gl/layers"); var _ = require("../"); function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } function _superPropGet(t, e, r, o) { var p = (0, _get2["default"])((0, _getPrototypeOf2["default"])(1 & o ? t.prototype : t), e, r); return 2 & o ? function (t) { return p.apply(r, t); } : p; } 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; } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var elevationScaleUniforms = { name: 'elevationScale', vs: "uniform elevationScaleUniforms {\n float elevationScale;\n} elevationScaleProps;\n", uniformTypes: { elevationScale: 'f32' } }; var defaultProps = _objectSpread(_objectSpread({}, _layers.LineLayer.defaultProps), {}, { getTargetColor: function getTargetColor(x) { return x.color || [0, 0, 0, 255]; } }); function addInstanceColorShader(vs) { var targetColorVs = (0, _.editShader)(vs, 'line target color vs', 'in vec4 instanceColors;', 'in vec4 instanceColors; in vec4 instanceTargetColors;'); return (0, _.editShader)(targetColorVs, 'line color vs', 'vColor = vec4(instanceColors.rgb, instanceColors.a * layer.opacity);', "vec4 color = mix(instanceColors, instanceTargetColors, positions.x);" + "vColor = vec4(color.rgb, color.a * layer.opacity);"); } function addElevationScale(vs) { return (0, _.editShader)(vs, 'line elevation scale vs - multiply by elevation scale', "geometry.worldPosition = instanceSourcePositions;\ngeometry.worldPositionAlt = instanceTargetPositions;\nvec3 source_world = instanceSourcePositions;\nvec3 target_world = instanceTargetPositions;", "vec3 source_world = instanceSourcePositions;\nvec3 target_world = instanceTargetPositions;\nsource_world.z *= elevationScaleProps.elevationScale;\ntarget_world.z *= elevationScaleProps.elevationScale;\ngeometry.worldPosition = source_world;\ngeometry.worldPositionAlt = target_world;"); } var EnhancedLineLayer = exports["default"] = /*#__PURE__*/function (_LineLayer) { function EnhancedLineLayer() { (0, _classCallCheck2["default"])(this, EnhancedLineLayer); return _callSuper(this, EnhancedLineLayer, arguments); } (0, _inherits2["default"])(EnhancedLineLayer, _LineLayer); return (0, _createClass2["default"])(EnhancedLineLayer, [{ key: "getShaders", value: function getShaders() { var shaders = _superPropGet(EnhancedLineLayer, "getShaders", this, 3)([]); var vs = addInstanceColorShader(shaders.vs); vs = addElevationScale(vs); return _objectSpread(_objectSpread({}, shaders), {}, { vs: vs, modules: [].concat((0, _toConsumableArray2["default"])(shaders.modules || []), [elevationScaleUniforms]) }); } }, { key: "draw", value: function draw(opts) { var model = this.state.model; if (model) { var _this$props$elevation; model.shaderInputs.setProps({ elevationScale: { elevationScale: (_this$props$elevation = this.props.elevationScale) !== null && _this$props$elevation !== void 0 ? _this$props$elevation : 1 } }); } _superPropGet(EnhancedLineLayer, "draw", this, 3)([opts]); } }, { key: "initializeState", value: function initializeState() { var _this$props$colorForm; _superPropGet(EnhancedLineLayer, "initializeState", this, 3)([]); var _ref = this.state, attributeManager = _ref.attributeManager; attributeManager.addInstanced({ instanceTargetColors: { size: (_this$props$colorForm = this.props.colorFormat) === null || _this$props$colorForm === void 0 ? void 0 : _this$props$colorForm.length, type: 'unorm8', transition: true, accessor: 'getTargetColor', defaultValue: [0, 0, 0, 255] } }); } }]); }(_layers.LineLayer); EnhancedLineLayer.layerName = 'EnhancedLineLayer'; EnhancedLineLayer.defaultProps = defaultProps; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_layers","require","_","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","_superPropGet","r","p","_get2","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","elevationScaleUniforms","name","vs","uniformTypes","elevationScale","defaultProps","LineLayer","getTargetColor","x","color","addInstanceColorShader","targetColorVs","editShader","addElevationScale","EnhancedLineLayer","exports","_LineLayer","_classCallCheck2","_inherits2","_createClass2","key","value","getShaders","shaders","modules","concat","_toConsumableArray2","draw","opts","model","state","_this$props$elevation","shaderInputs","setProps","props","initializeState","_this$props$colorForm","_ref","attributeManager","addInstanced","instanceTargetColors","size","colorFormat","type","transition","accessor","defaultValue","layerName"],"sources":["../../src/line-layer/line-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {LineLayer, LineLayerProps} from '@deck.gl/layers';\nimport type {Color, AttributeManager} from '@deck.gl/core';\nimport {editShader} from '../';\n\ntype RGBAColor = Color;\n\nconst elevationScaleUniforms = {\n  name: 'elevationScale',\n  vs: `uniform elevationScaleUniforms {\n  float elevationScale;\n} elevationScaleProps;\n`,\n  uniformTypes: {\n    elevationScale: 'f32'\n  }\n};\n\nconst defaultProps = {\n  ...LineLayer.defaultProps,\n  getTargetColor: x => x.color || [0, 0, 0, 255]\n};\n\nfunction addInstanceColorShader(vs) {\n  const targetColorVs = editShader(\n    vs,\n    'line target color vs',\n    'in vec4 instanceColors;',\n    'in vec4 instanceColors; in vec4 instanceTargetColors;'\n  );\n\n  return editShader(\n    targetColorVs,\n    'line color vs',\n    'vColor = vec4(instanceColors.rgb, instanceColors.a * layer.opacity);',\n    `vec4 color = mix(instanceColors, instanceTargetColors, positions.x);` +\n      `vColor = vec4(color.rgb, color.a * layer.opacity);`\n  );\n}\n\nfunction addElevationScale(vs) {\n  return editShader(\n    vs,\n    'line elevation scale vs - multiply by elevation scale',\n    `geometry.worldPosition = instanceSourcePositions;\ngeometry.worldPositionAlt = instanceTargetPositions;\nvec3 source_world = instanceSourcePositions;\nvec3 target_world = instanceTargetPositions;`,\n    `vec3 source_world = instanceSourcePositions;\nvec3 target_world = instanceTargetPositions;\nsource_world.z *= elevationScaleProps.elevationScale;\ntarget_world.z *= elevationScaleProps.elevationScale;\ngeometry.worldPosition = source_world;\ngeometry.worldPositionAlt = target_world;`\n  );\n}\n\nexport default class EnhancedLineLayer extends LineLayer<\n  any,\n  LineLayerProps<any> & {elevationScale: number; getTargetColor: RGBAColor}\n> {\n  getShaders() {\n    const shaders = super.getShaders();\n\n    let vs = addInstanceColorShader(shaders.vs);\n    vs = addElevationScale(vs);\n\n    return {\n      ...shaders,\n      vs,\n      modules: [...(shaders.modules || []), elevationScaleUniforms]\n    };\n  }\n\n  draw(opts) {\n    const model = this.state.model;\n    if (model) {\n      model.shaderInputs.setProps({\n        elevationScale: {\n          elevationScale: this.props.elevationScale ?? 1\n        }\n      });\n    }\n    super.draw(opts);\n  }\n\n  initializeState() {\n    super.initializeState();\n    const {attributeManager} = this.state as {attributeManager: AttributeManager};\n    attributeManager.addInstanced({\n      instanceTargetColors: {\n        size: this.props.colorFormat?.length,\n        type: 'unorm8',\n        transition: true,\n        accessor: 'getTargetColor',\n        defaultValue: [0, 0, 0, 255]\n      }\n    });\n  }\n}\n\nEnhancedLineLayer.layerName = 'EnhancedLineLayer';\nEnhancedLineLayer.defaultProps = defaultProps;\n"],"mappings":"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","ignoreList":[]}