kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
135 lines (134 loc) • 19.8 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
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 _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 _layers = require("@deck.gl/layers");
var _core = require("@deck.gl/core");
var _ = require("../");
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 _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; } // SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
function addInstanceCoverage(vs) {
var addDecl = (0, _.editShader)(vs, 'hexagon cell vs add instance 1', 'in vec3 instancePickingColors;', "in vec3 instancePickingColors;\n in float instanceCoverage;");
return (0, _.editShader)(addDecl, 'hexagon cell vs add instance 2', 'float dotRadius = column.radius * column.coverage * shouldRender;', 'float dotRadius = column.radius * column.coverage * instanceCoverage * shouldRender;');
}
var EnhancedColumnLayer = /*#__PURE__*/function (_ColumnLayer) {
function EnhancedColumnLayer() {
(0, _classCallCheck2["default"])(this, EnhancedColumnLayer);
return _callSuper(this, EnhancedColumnLayer, arguments);
}
(0, _inherits2["default"])(EnhancedColumnLayer, _ColumnLayer);
return (0, _createClass2["default"])(EnhancedColumnLayer, [{
key: "getShaders",
value: function getShaders() {
var shaders = _superPropGet(EnhancedColumnLayer, "getShaders", this, 3)([]);
return _objectSpread(_objectSpread({}, shaders), {}, {
vs: addInstanceCoverage(shaders.vs)
});
}
}, {
key: "initializeState",
value: function initializeState() {
var _this$getAttributeMan;
_superPropGet(EnhancedColumnLayer, "initializeState", this, 3)([]);
(_this$getAttributeMan = this.getAttributeManager()) === null || _this$getAttributeMan === void 0 || _this$getAttributeMan.addInstanced({
instanceCoverage: {
size: 1,
accessor: 'getCoverage'
}
});
}
}, {
key: "draw",
value: function draw(_ref) {
var _uniforms = _ref.uniforms;
var _this$props = this.props,
lineWidthUnits = _this$props.lineWidthUnits,
lineWidthScale = _this$props.lineWidthScale,
lineWidthMinPixels = _this$props.lineWidthMinPixels,
lineWidthMaxPixels = _this$props.lineWidthMaxPixels,
radiusUnits = _this$props.radiusUnits,
elevationScale = _this$props.elevationScale,
extruded = _this$props.extruded,
filled = _this$props.filled,
stroked = _this$props.stroked,
strokeOpacity = _this$props.strokeOpacity,
wireframe = _this$props.wireframe,
offset = _this$props.offset,
coverage = _this$props.coverage,
radius = _this$props.radius,
angle = _this$props.angle;
var fillModel = this.state.fillModel;
var wireframeModel = this.state.wireframeModel;
var _this$state = this.state,
fillVertexCount = _this$state.fillVertexCount,
edgeDistance = _this$state.edgeDistance;
var columnProps = {
radius: radius,
angle: angle / 180 * Math.PI,
offset: offset,
extruded: extruded,
stroked: stroked,
coverage: coverage,
elevationScale: elevationScale,
edgeDistance: edgeDistance,
radiusUnits: _core.UNIT[radiusUnits],
widthUnits: _core.UNIT[lineWidthUnits],
widthScale: lineWidthScale,
widthMinPixels: lineWidthMinPixels,
widthMaxPixels: lineWidthMaxPixels
};
if (extruded && wireframe && wireframeModel) {
wireframeModel.shaderInputs.setProps({
column: _objectSpread(_objectSpread({}, columnProps), {}, {
isStroke: true
})
});
wireframeModel.draw(this.context.renderPass);
}
if (filled && fillModel) {
fillModel.setVertexCount(fillVertexCount);
fillModel.shaderInputs.setProps({
column: _objectSpread(_objectSpread({}, columnProps), {}, {
isStroke: false
})
});
fillModel.draw(this.context.renderPass);
}
if (!extruded && stroked && fillModel) {
fillModel.setVertexCount(fillVertexCount * 2 / 3);
fillModel.shaderInputs.setProps({
column: _objectSpread(_objectSpread({}, columnProps), {}, {
isStroke: true
}),
layer: {
opacity: strokeOpacity !== null && strokeOpacity !== void 0 ? strokeOpacity : this.props.opacity
}
});
fillModel.draw(this.context.renderPass);
// Restore original vertex count and opacity so subsequent passes are unaffected
fillModel.setVertexCount(fillVertexCount);
fillModel.shaderInputs.setProps({
layer: {
opacity: this.props.opacity
}
});
}
}
}]);
}(_layers.ColumnLayer);
EnhancedColumnLayer.layerName = 'EnhancedColumnLayer';
var _default = exports["default"] = EnhancedColumnLayer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_layers","require","_core","_","ownKeys","e","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","defineProperty","_callSuper","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","Boolean","prototype","valueOf","call","_superPropGet","p","_get2","addInstanceCoverage","vs","addDecl","editShader","EnhancedColumnLayer","_ColumnLayer","_classCallCheck2","_inherits2","_createClass2","key","value","getShaders","shaders","initializeState","_this$getAttributeMan","getAttributeManager","addInstanced","instanceCoverage","size","accessor","draw","_ref","_uniforms","uniforms","_this$props","props","lineWidthUnits","lineWidthScale","lineWidthMinPixels","lineWidthMaxPixels","radiusUnits","elevationScale","extruded","filled","stroked","strokeOpacity","wireframe","offset","coverage","radius","angle","fillModel","state","wireframeModel","_this$state","fillVertexCount","edgeDistance","columnProps","Math","PI","UNIT","widthUnits","widthScale","widthMinPixels","widthMaxPixels","shaderInputs","setProps","column","isStroke","context","renderPass","setVertexCount","layer","opacity","ColumnLayer","layerName","_default","exports"],"sources":["../../src/column-layer/enhanced-column-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {ColumnLayer, ColumnLayerProps} from '@deck.gl/layers';\nimport {UNIT} from '@deck.gl/core';\n\nimport {editShader} from '../';\n\nfunction addInstanceCoverage(vs: string) {\n  const addDecl = editShader(\n    vs,\n    'hexagon cell vs add instance 1',\n    'in vec3 instancePickingColors;',\n    `in vec3 instancePickingColors;\n     in float instanceCoverage;`\n  );\n\n  return editShader(\n    addDecl,\n    'hexagon cell vs add instance 2',\n    'float dotRadius = column.radius * column.coverage * shouldRender;',\n    'float dotRadius = column.radius * column.coverage * instanceCoverage * shouldRender;'\n  );\n}\n\ntype EnhancedColumnLayerProps = ColumnLayerProps<any> & {\n  strokeOpacity: number;\n};\n\nclass EnhancedColumnLayer extends ColumnLayer<any, EnhancedColumnLayerProps> {\n  getShaders() {\n    const shaders = super.getShaders();\n\n    return {\n      ...shaders,\n      vs: addInstanceCoverage(shaders.vs)\n    };\n  }\n\n  initializeState() {\n    super.initializeState();\n\n    this.getAttributeManager()?.addInstanced({\n      instanceCoverage: {size: 1, accessor: 'getCoverage'}\n    });\n  }\n\n  draw({uniforms: _uniforms}) {\n    const {\n      lineWidthUnits,\n      lineWidthScale,\n      lineWidthMinPixels,\n      lineWidthMaxPixels,\n      radiusUnits,\n      elevationScale,\n      extruded,\n      filled,\n      stroked,\n      strokeOpacity,\n      wireframe,\n      offset,\n      coverage,\n      radius,\n      angle\n    } = this.props;\n    const fillModel = this.state.fillModel;\n    const wireframeModel = this.state.wireframeModel;\n    const {fillVertexCount, edgeDistance} = this.state;\n\n    const columnProps = {\n      radius,\n      angle: (angle / 180) * Math.PI,\n      offset,\n      extruded,\n      stroked,\n      coverage,\n      elevationScale,\n      edgeDistance,\n      radiusUnits: UNIT[radiusUnits],\n      widthUnits: UNIT[lineWidthUnits],\n      widthScale: lineWidthScale,\n      widthMinPixels: lineWidthMinPixels,\n      widthMaxPixels: lineWidthMaxPixels\n    };\n\n    if (extruded && wireframe && wireframeModel) {\n      wireframeModel.shaderInputs.setProps({\n        column: {...columnProps, isStroke: true}\n      });\n      wireframeModel.draw(this.context.renderPass);\n    }\n    if (filled && fillModel) {\n      fillModel.setVertexCount(fillVertexCount);\n      fillModel.shaderInputs.setProps({\n        column: {...columnProps, isStroke: false}\n      });\n      fillModel.draw(this.context.renderPass);\n    }\n    if (!extruded && stroked && fillModel) {\n      fillModel.setVertexCount((fillVertexCount * 2) / 3);\n      fillModel.shaderInputs.setProps({\n        column: {...columnProps, isStroke: true},\n        layer: {opacity: strokeOpacity ?? this.props.opacity}\n      });\n      fillModel.draw(this.context.renderPass);\n      // Restore original vertex count and opacity so subsequent passes are unaffected\n      fillModel.setVertexCount(fillVertexCount);\n      fillModel.shaderInputs.setProps({\n        layer: {opacity: this.props.opacity}\n      });\n    }\n  }\n}\n\nEnhancedColumnLayer.layerName = 'EnhancedColumnLayer';\n\nexport default EnhancedColumnLayer;\n"],"mappings":"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","ignoreList":[]}