UNPKG

kepler.gl

Version:

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

257 lines (248 loc) 37.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 _typed = require("@deck.gl/core/typed"); var _typed2 = require("@deck.gl/mesh-layers/typed"); var _constants = _interopRequireDefault(require("@luma.gl/constants")); var _core = require("@luma.gl/core"); var _engine = require("@luma.gl/engine"); var _rasterMeshLayerWebgl = _interopRequireDefault(require("./raster-mesh-layer-webgl1.fs")); var _rasterMeshLayerWebgl2 = _interopRequireDefault(require("./raster-mesh-layer-webgl1.vs")); var _rasterMeshLayerWebgl3 = _interopRequireDefault(require("./raster-mesh-layer-webgl2.fs")); var _rasterMeshLayerWebgl4 = _interopRequireDefault(require("./raster-mesh-layer-webgl2.vs")); var _images = require("../images"); var _util = require("../util"); function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; } function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } } function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; } 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 function validateGeometryAttributes(attributes) { _typed.log.assert(attributes.positions || attributes.POSITION, 'RasterMeshLayer requires "postions" or "POSITION" attribute in mesh property.'); } /* * Convert mesh data into geometry * @returns geometry */ function getGeometry(data) { if (data.attributes) { validateGeometryAttributes(data.attributes); if (data instanceof _core.Geometry) { return data; } return new _core.Geometry(data); } else if (data.positions || data.POSITION) { validateGeometryAttributes(data); return new _core.Geometry({ attributes: data }); } throw Error('Invalid mesh'); } var defaultProps = _objectSpread(_objectSpread({}, _typed2.SimpleMeshLayer.defaultProps), {}, { modules: { type: 'array', value: [], compare: true }, images: { type: 'object', value: {}, compare: true }, moduleProps: { type: 'object', value: {}, compare: true } }); var RasterMeshLayer = exports["default"] = /*#__PURE__*/function (_SimpleMeshLayer) { function RasterMeshLayer() { (0, _classCallCheck2["default"])(this, RasterMeshLayer); return _callSuper(this, RasterMeshLayer, arguments); } (0, _inherits2["default"])(RasterMeshLayer, _SimpleMeshLayer); return (0, _createClass2["default"])(RasterMeshLayer, [{ key: "initializeState", value: function initializeState() { var gl = this.context.gl; var programManager = _engine.ProgramManager.getDefaultProgramManager(gl); var fsStr1 = 'fs:DECKGL_MUTATE_COLOR(inout vec4 image, in vec2 coord)'; var fsStr2 = 'fs:DECKGL_CREATE_COLOR(inout vec4 image, in vec2 coord)'; // Only initialize shader hook functions _once globally_ // Since the program manager is shared across all layers, but many layers // might be created, this solves the performance issue of always adding new // hook functions. if (!programManager._hookFunctions.includes(fsStr1)) { programManager.addShaderHook(fsStr1); } if (!programManager._hookFunctions.includes(fsStr2)) { programManager.addShaderHook(fsStr2); } // images is a mapping from keys to Texture2D objects. The keys should match // names of uniforms in shader modules this.setState({ images: {} }); _superPropGet(RasterMeshLayer, "initializeState", this, 3)([]); } }, { key: "getShaders", value: function getShaders() { var gl = this.context.gl; var _this$props$modules = this.props.modules, modules = _this$props$modules === void 0 ? [] : _this$props$modules; var webgl2 = (0, _core.isWebGL2)(gl); // Choose webgl version for module // If fs2 or fs1 keys exist, prefer them, but fall back to fs, so that // version-independent modules don't need to care var _iterator = _createForOfIteratorHelper(modules), _step; try { for (_iterator.s(); !(_step = _iterator.n()).done;) { var module = _step.value; module.fs = webgl2 ? module.fs2 || module.fs : module.fs1 || module.fs; // Sampler type is always float for WebGL1 if (!webgl2 && module.defines) { module.defines.SAMPLER_TYPE = 'sampler2D'; } } } catch (err) { _iterator.e(err); } finally { _iterator.f(); } return _objectSpread(_objectSpread({}, _superPropGet(RasterMeshLayer, "getShaders", this, 3)([])), {}, { vs: webgl2 ? _rasterMeshLayerWebgl4["default"] : _rasterMeshLayerWebgl2["default"], fs: webgl2 ? _rasterMeshLayerWebgl3["default"] : _rasterMeshLayerWebgl["default"], modules: [_typed.project32, _typed.phongLighting].concat((0, _toConsumableArray2["default"])(modules)) }); } // eslint-disable-next-line complexity }, { key: "updateState", value: function updateState(params) { var props = params.props, oldProps = params.oldProps, changeFlags = params.changeFlags, context = params.context; _superPropGet(RasterMeshLayer, "updateState", this, 3)([{ props: props, oldProps: oldProps, changeFlags: changeFlags, context: context }]); var modules = props && props.modules; var oldModules = oldProps && oldProps.modules; // If the list of modules changed, need to recompile the shaders if (props.mesh !== oldProps.mesh || changeFlags.extensionsChanged || !(0, _util.modulesEqual)(modules, oldModules)) { var _this$getAttributeMan; if (this.state.model) { this.state.model["delete"](); } if (props.mesh) { this.state.model = this.getModel(props.mesh); var attributes = props.mesh.attributes || props.mesh; this.setState({ hasNormals: Boolean(attributes.NORMAL || attributes.normals) }); } (_this$getAttributeMan = this.getAttributeManager()) === null || _this$getAttributeMan === void 0 || _this$getAttributeMan.invalidateAll(); } if (props && props.images) { this.updateImages({ props: props, oldProps: oldProps }); } if (this.state.model) { this.state.model.setDrawMode(this.props.wireframe ? _constants["default"].LINE_STRIP : _constants["default"].TRIANGLES); } } }, { key: "updateImages", value: function updateImages(_ref) { var props = _ref.props, oldProps = _ref.oldProps; var images = this.state.images; var gl = this.context.gl; var newImages = (0, _images.loadImages)({ gl: gl, images: images, imagesData: props.images, oldImagesData: oldProps.images }); if (newImages) { this.setState({ images: newImages }); } } }, { key: "draw", value: function draw(_ref2) { var uniforms = _ref2.uniforms; var _this$state = this.state, model = _this$state.model, images = _this$state.images; var moduleProps = this.props.moduleProps; // Render the image if (!model || !images || Object.keys(images).length === 0 || !Object.values(images).every(function (item) { return item; })) { return; } var sizeScale = this.props.sizeScale; model.setUniforms(Object.assign({}, uniforms, { sizeScale: sizeScale, flatShading: !this.state.hasNormals })).updateModuleSettings(_objectSpread(_objectSpread({}, moduleProps), images)).draw(); } }, { key: "finalizeState", value: function finalizeState() { _superPropGet(RasterMeshLayer, "finalizeState", this, 3)([this.context]); if (this.state.images) { for (var _i = 0, _Object$values = Object.values(this.state.images); _i < _Object$values.length; _i++) { var image = _Object$values[_i]; if (Array.isArray(image)) { image.map(function (x) { return x && x["delete"](); }); } else if (image) { image["delete"](); } } } } }, { key: "getModel", value: function getModel(mesh) { var gl = this.context.gl; var model = new _core.Model(gl, Object.assign({}, this.getShaders(), { id: this.props.id, geometry: getGeometry(mesh), isInstanced: false })); return model; } }]); }(_typed2.SimpleMeshLayer); RasterMeshLayer.layerName = 'RasterMeshLayer'; RasterMeshLayer.defaultProps = defaultProps; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_typed","require","_typed2","_constants","_interopRequireDefault","_core","_engine","_rasterMeshLayerWebgl","_rasterMeshLayerWebgl2","_rasterMeshLayerWebgl3","_rasterMeshLayerWebgl4","_images","_util","_createForOfIteratorHelper","r","e","t","Symbol","iterator","Array","isArray","_unsupportedIterableToArray","length","_n","F","s","n","done","value","f","TypeError","o","a","u","call","next","_arrayLikeToArray","toString","slice","constructor","name","from","test","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","apply","Boolean","prototype","valueOf","_superPropGet","p","_get2","ownKeys","Object","keys","getOwnPropertySymbols","filter","getOwnPropertyDescriptor","enumerable","push","_objectSpread","arguments","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","validateGeometryAttributes","attributes","log","assert","positions","POSITION","getGeometry","data","Geometry","Error","defaultProps","SimpleMeshLayer","modules","type","compare","images","moduleProps","RasterMeshLayer","exports","_SimpleMeshLayer","_classCallCheck2","_inherits2","_createClass2","key","initializeState","gl","context","programManager","ProgramManager","getDefaultProgramManager","fsStr1","fsStr2","_hookFunctions","includes","addShaderHook","setState","getShaders","_this$props$modules","props","webgl2","isWebGL2","_iterator","_step","module","fs","fs2","fs1","defines","SAMPLER_TYPE","err","vs","vsWebGL2","vsWebGL1","fsWebGL2","fsWebGL1","project32","phongLighting","concat","_toConsumableArray2","updateState","params","oldProps","changeFlags","oldModules","mesh","extensionsChanged","modulesEqual","_this$getAttributeMan","state","model","getModel","hasNormals","NORMAL","normals","getAttributeManager","invalidateAll","updateImages","setDrawMode","wireframe","GL","LINE_STRIP","TRIANGLES","_ref","newImages","loadImages","imagesData","oldImagesData","draw","_ref2","uniforms","_this$state","values","every","item","sizeScale","setUniforms","assign","flatShading","updateModuleSettings","finalizeState","_i","_Object$values","image","map","x","Model","id","geometry","isInstanced","layerName"],"sources":["../../../src/raster/raster-mesh-layer/raster-mesh-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {project32, phongLighting, log, UpdateParameters} from '@deck.gl/core/typed';\nimport {SimpleMeshLayer, SimpleMeshLayerProps} from '@deck.gl/mesh-layers/typed';\nimport GL from '@luma.gl/constants';\nimport {Model, Geometry, isWebGL2} from '@luma.gl/core';\nimport {ProgramManager} from '@luma.gl/engine';\nimport {UniformsOptions} from '@luma.gl/webgl/src/classes/uniforms';\n\nimport fsWebGL1 from './raster-mesh-layer-webgl1.fs';\nimport vsWebGL1 from './raster-mesh-layer-webgl1.vs';\nimport fsWebGL2 from './raster-mesh-layer-webgl2.fs';\nimport vsWebGL2 from './raster-mesh-layer-webgl2.vs';\nimport {loadImages} from '../images';\nimport type {RasterLayerAddedProps, ImageState} from '../types';\nimport {modulesEqual} from '../util';\n\ntype Mesh = SimpleMeshLayerProps['mesh'];\n\nfunction validateGeometryAttributes(attributes) {\n  log.assert(\n    attributes.positions || attributes.POSITION,\n    'RasterMeshLayer requires \"postions\" or \"POSITION\" attribute in mesh property.'\n  );\n}\n\n/*\n * Convert mesh data into geometry\n * @returns geometry\n */\nfunction getGeometry(data): Geometry {\n  if (data.attributes) {\n    validateGeometryAttributes(data.attributes);\n    if (data instanceof Geometry) {\n      return data;\n    }\n    return new Geometry(data);\n  } else if (data.positions || data.POSITION) {\n    validateGeometryAttributes(data);\n    return new Geometry({\n      attributes: data\n    });\n  }\n  throw Error('Invalid mesh');\n}\n\nconst defaultProps = {\n  ...SimpleMeshLayer.defaultProps,\n  modules: {type: 'array', value: [], compare: true},\n  images: {type: 'object', value: {}, compare: true},\n  moduleProps: {type: 'object', value: {}, compare: true}\n};\n\nexport default class RasterMeshLayer extends SimpleMeshLayer<any, RasterLayerAddedProps> {\n  declare state: SimpleMeshLayer<RasterLayerAddedProps>['state'] & {\n    images: ImageState;\n  };\n\n  initializeState(): void {\n    const {gl} = this.context;\n    const programManager = ProgramManager.getDefaultProgramManager(gl);\n\n    const fsStr1 = 'fs:DECKGL_MUTATE_COLOR(inout vec4 image, in vec2 coord)';\n    const fsStr2 = 'fs:DECKGL_CREATE_COLOR(inout vec4 image, in vec2 coord)';\n\n    // Only initialize shader hook functions _once globally_\n    // Since the program manager is shared across all layers, but many layers\n    // might be created, this solves the performance issue of always adding new\n    // hook functions.\n    if (!programManager._hookFunctions.includes(fsStr1)) {\n      programManager.addShaderHook(fsStr1);\n    }\n    if (!programManager._hookFunctions.includes(fsStr2)) {\n      programManager.addShaderHook(fsStr2);\n    }\n\n    // images is a mapping from keys to Texture2D objects. The keys should match\n    // names of uniforms in shader modules\n    this.setState({images: {}});\n\n    super.initializeState();\n  }\n\n  getShaders(): any {\n    const {gl} = this.context;\n    const {modules = []} = this.props;\n    const webgl2 = isWebGL2(gl);\n\n    // Choose webgl version for module\n    // If fs2 or fs1 keys exist, prefer them, but fall back to fs, so that\n    // version-independent modules don't need to care\n    for (const module of modules) {\n      module.fs = webgl2 ? module.fs2 || module.fs : module.fs1 || module.fs;\n\n      // Sampler type is always float for WebGL1\n      if (!webgl2 && module.defines) {\n        module.defines.SAMPLER_TYPE = 'sampler2D';\n      }\n    }\n\n    return {\n      ...super.getShaders(),\n      vs: webgl2 ? vsWebGL2 : vsWebGL1,\n      fs: webgl2 ? fsWebGL2 : fsWebGL1,\n      modules: [project32, phongLighting, ...modules]\n    };\n  }\n\n  // eslint-disable-next-line complexity\n  updateState(params: UpdateParameters<SimpleMeshLayer<any, RasterLayerAddedProps>>): void {\n    const {props, oldProps, changeFlags, context} = params;\n    super.updateState({props, oldProps, changeFlags, context});\n\n    const modules = props && props.modules;\n    const oldModules = oldProps && oldProps.modules;\n\n    // If the list of modules changed, need to recompile the shaders\n    if (\n      props.mesh !== oldProps.mesh ||\n      changeFlags.extensionsChanged ||\n      !modulesEqual(modules, oldModules)\n    ) {\n      if (this.state.model) {\n        this.state.model.delete();\n      }\n      if (props.mesh) {\n        this.state.model = this.getModel(props.mesh as Mesh);\n\n        const attributes = (props.mesh as any).attributes || props.mesh;\n        this.setState({\n          hasNormals: Boolean(attributes.NORMAL || attributes.normals)\n        });\n      }\n      this.getAttributeManager()?.invalidateAll();\n    }\n\n    if (props && props.images) {\n      this.updateImages({props, oldProps});\n    }\n\n    if (this.state.model) {\n      this.state.model.setDrawMode(this.props.wireframe ? GL.LINE_STRIP : GL.TRIANGLES);\n    }\n  }\n\n  updateImages({\n    props,\n    oldProps\n  }: {\n    props: RasterLayerAddedProps;\n    oldProps: RasterLayerAddedProps;\n  }): void {\n    const {images} = this.state;\n    const {gl} = this.context;\n\n    const newImages = loadImages({\n      gl,\n      images,\n      imagesData: props.images,\n      oldImagesData: oldProps.images\n    });\n\n    if (newImages) {\n      this.setState({images: newImages});\n    }\n  }\n\n  draw({uniforms}: UniformsOptions): void {\n    const {model, images} = this.state;\n    const {moduleProps} = this.props;\n\n    // Render the image\n    if (\n      !model ||\n      !images ||\n      Object.keys(images).length === 0 ||\n      !Object.values(images).every(item => item)\n    ) {\n      return;\n    }\n\n    const {sizeScale} = this.props;\n\n    model\n      .setUniforms(\n        Object.assign({}, uniforms, {\n          sizeScale,\n          flatShading: !this.state.hasNormals\n        })\n      )\n      .updateModuleSettings({\n        ...moduleProps,\n        ...images\n      })\n      .draw();\n  }\n\n  finalizeState(): void {\n    super.finalizeState(this.context);\n\n    if (this.state.images) {\n      for (const image of Object.values(this.state.images)) {\n        if (Array.isArray(image)) {\n          image.map(x => x && x.delete());\n        } else if (image) {\n          image.delete();\n        }\n      }\n    }\n  }\n\n  protected getModel(mesh: Mesh): Model {\n    const {gl} = this.context;\n\n    const model = new Model(\n      gl,\n      Object.assign({}, this.getShaders(), {\n        id: this.props.id,\n        geometry: getGeometry(mesh),\n        isInstanced: false\n      })\n    );\n\n    return model;\n  }\n}\n\nRasterMeshLayer.layerName = 'RasterMeshLayer';\nRasterMeshLayer.defaultProps = defaultProps;\n"],"mappings":"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","ignoreList":[]}