kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
87 lines (86 loc) • 16.1 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
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 _constants = _interopRequireDefault(require("@luma.gl/constants"));
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 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', 'attribute vec4 instanceColors;', 'attribute vec4 instanceColors; attribute vec4 instanceTargetColors;');
return (0, _.editShader)(targetColorVs, 'line color vs', 'vColor = vec4(instanceColors.rgb, instanceColors.a * opacity);', "vec4 color = mix(instanceColors, instanceTargetColors, positions.x);" + "vColor = vec4(color.rgb, color.a * opacity);");
}
function addElevationScale(vs) {
var elevationVs = (0, _.editShader)(vs, 'line elevation scale 1 vs - inject elevation scale', 'uniform float widthMaxPixels;', "uniform float widthMaxPixels;\n uniform float elevationScale;");
elevationVs = (0, _.editShader)(elevationVs, 'line elevation scale 2 vs - multiply by elevation scale', "geometry.worldPosition = instanceSourcePositions;\n geometry.worldPositionAlt = instanceTargetPositions;", "vec3 source_world = instanceSourcePositions;\n vec3 target_world = instanceTargetPositions;\n source_world.z *= elevationScale;\n target_world.z *= elevationScale;\n \n geometry.worldPosition = source_world;\n geometry.worldPositionAlt = target_world;");
elevationVs = (0, _.editShader)(elevationVs, 'line elevation scale 3 vs', "vec3 source_world = instanceSourcePositions;\n vec3 target_world = instanceTargetPositions;", '');
return elevationVs;
}
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
});
}
}, {
key: "draw",
value: function draw(_ref) {
var uniforms = _ref.uniforms;
var elevationScale = this.props.elevationScale;
_superPropGet(EnhancedLineLayer, "draw", this, 3)([{
uniforms: _objectSpread(_objectSpread({}, uniforms), {}, {
elevationScale: elevationScale
})
}]);
}
}, {
key: "initializeState",
value: function initializeState() {
var _this$props$colorForm;
_superPropGet(EnhancedLineLayer, "initializeState", this, 3)([undefined]);
var attributeManager = this.state.attributeManager;
attributeManager.addInstanced({
instanceTargetColors: {
size: (_this$props$colorForm = this.props.colorFormat) === null || _this$props$colorForm === void 0 ? void 0 : _this$props$colorForm.length,
type: _constants["default"].UNSIGNED_BYTE,
normalized: true,
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","_constants","_interopRequireDefault","_","_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","defaultProps","LineLayer","getTargetColor","x","color","addInstanceColorShader","vs","targetColorVs","editShader","addElevationScale","elevationVs","EnhancedLineLayer","exports","_LineLayer","_classCallCheck2","_inherits2","_createClass2","key","value","getShaders","shaders","draw","_ref","uniforms","elevationScale","props","initializeState","_this$props$colorForm","undefined","attributeManager","state","addInstanced","instanceTargetColors","size","colorFormat","type","GL","UNSIGNED_BYTE","normalized","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 GL from '@luma.gl/constants';\nimport {RGBAColor} from 'deck.gl';\nimport {editShader} from '../';\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    'attribute vec4 instanceColors;',\n    'attribute vec4 instanceColors; attribute vec4 instanceTargetColors;'\n  );\n\n  return editShader(\n    targetColorVs,\n    'line color vs',\n    'vColor = vec4(instanceColors.rgb, instanceColors.a * opacity);',\n    `vec4 color = mix(instanceColors, instanceTargetColors, positions.x);` +\n      `vColor = vec4(color.rgb, color.a * opacity);`\n  );\n}\n\nfunction addElevationScale(vs) {\n  let elevationVs = editShader(\n    vs,\n    'line elevation scale 1 vs - inject elevation scale',\n    'uniform float widthMaxPixels;',\n    `uniform float widthMaxPixels;\n     uniform float elevationScale;`\n  );\n\n  elevationVs = editShader(\n    elevationVs,\n    'line elevation scale 2 vs - multiply by elevation scale',\n    `geometry.worldPosition = instanceSourcePositions;\n  geometry.worldPositionAlt = instanceTargetPositions;`,\n    `vec3 source_world = instanceSourcePositions;\n     vec3 target_world = instanceTargetPositions;\n     source_world.z *= elevationScale;\n     target_world.z *= elevationScale;\n     \n     geometry.worldPosition = source_world;\n     geometry.worldPositionAlt = target_world;`\n  );\n\n  elevationVs = editShader(\n    elevationVs,\n    'line elevation scale 3 vs',\n    `vec3 source_world = instanceSourcePositions;\n  vec3 target_world = instanceTargetPositions;`,\n    ''\n  );\n\n  return elevationVs;\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    };\n  }\n\n  draw({uniforms}) {\n    const {elevationScale} = this.props;\n    super.draw({uniforms: {...uniforms, elevationScale}});\n  }\n\n  initializeState() {\n    super.initializeState(undefined);\n    const {attributeManager} = this.state;\n    attributeManager.addInstanced({\n      instanceTargetColors: {\n        size: this.props.colorFormat?.length,\n        type: GL.UNSIGNED_BYTE,\n        normalized: true,\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":[]}
;