kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
131 lines (129 loc) • 19.6 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 _core = require("@deck.gl/core");
var _typed = require("@deck.gl/layers/typed");
var _constants = _interopRequireDefault(require("@luma.gl/constants"));
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 = radius * coverage * shouldRender;', 'float dotRadius = radius * coverage * instanceCoverage * shouldRender;');
}
// TODO: export all deck.gl layers from kepler.gl
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 _this$state = this.state,
model = _this$state.model,
fillVertexCount = _this$state.fillVertexCount,
wireframeVertexCount = _this$state.wireframeVertexCount,
edgeDistance = _this$state.edgeDistance;
model.setUniforms(uniforms).setUniforms({
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
});
// When drawing 3d: draw wireframe first so it doesn't get occluded by depth test
if (extruded && wireframe) {
model.setProps({
isIndexed: true
});
model.setVertexCount(wireframeVertexCount).setDrawMode(_constants["default"].LINES).setUniforms({
isStroke: true
}).draw();
}
if (filled) {
model.setProps({
isIndexed: false
});
model.setVertexCount(fillVertexCount).setDrawMode(_constants["default"].TRIANGLE_STRIP).setUniforms({
isStroke: false
}).draw();
}
// When drawing 2d: draw fill before stroke so that the outline is always on top
if (!extruded && stroked) {
model.setProps({
isIndexed: false
});
// The width of the stroke is achieved by flattening the side of the cylinder.
// Skip the last 1/3 of the vertices which is the top.
model.setVertexCount(fillVertexCount * 2 / 3).setDrawMode(_constants["default"].TRIANGLE_STRIP).setUniforms({
isStroke: true,
opacity: strokeOpacity
}).draw();
}
}
}]);
}(_typed.ColumnLayer);
EnhancedColumnLayer.layerName = 'EnhancedColumnLayer';
var _default = exports["default"] = EnhancedColumnLayer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_core","require","_typed","_constants","_interopRequireDefault","_","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","_this$props","props","lineWidthUnits","lineWidthScale","lineWidthMinPixels","lineWidthMaxPixels","radiusUnits","elevationScale","extruded","filled","stroked","strokeOpacity","wireframe","offset","coverage","radius","angle","_this$state","state","model","fillVertexCount","wireframeVertexCount","edgeDistance","setUniforms","Math","PI","UNIT","widthUnits","widthScale","widthMinPixels","widthMaxPixels","setProps","isIndexed","setVertexCount","setDrawMode","GL","LINES","isStroke","TRIANGLE_STRIP","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 {UNIT} from '@deck.gl/core';\nimport {ColumnLayer, ColumnLayerProps} from '@deck.gl/layers/typed';\nimport GL from '@luma.gl/constants';\n\nimport {editShader} from '../';\n\nfunction addInstanceCoverage(vs) {\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 = radius * coverage * shouldRender;',\n    'float dotRadius = radius * coverage * instanceCoverage * shouldRender;'\n  );\n}\n\ntype EnhancedColumnLayerProps = ColumnLayerProps<any> & {\n  strokeOpacity: any;\n};\n\n// TODO: export all deck.gl layers from kepler.gl\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}) {\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 {model, fillVertexCount, wireframeVertexCount, edgeDistance} = this.state;\n\n    model.setUniforms(uniforms).setUniforms({\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    // When drawing 3d: draw wireframe first so it doesn't get occluded by depth test\n    if (extruded && wireframe) {\n      model.setProps({isIndexed: true});\n      model\n        .setVertexCount(wireframeVertexCount)\n        .setDrawMode(GL.LINES)\n        .setUniforms({isStroke: true})\n        .draw();\n    }\n    if (filled) {\n      model.setProps({isIndexed: false});\n      model\n        .setVertexCount(fillVertexCount)\n        .setDrawMode(GL.TRIANGLE_STRIP)\n        .setUniforms({isStroke: false})\n        .draw();\n    }\n    // When drawing 2d: draw fill before stroke so that the outline is always on top\n    if (!extruded && stroked) {\n      model.setProps({isIndexed: false});\n      // The width of the stroke is achieved by flattening the side of the cylinder.\n      // Skip the last 1/3 of the vertices which is the top.\n      model\n        .setVertexCount((fillVertexCount * 2) / 3)\n        .setDrawMode(GL.TRIANGLE_STRIP)\n        .setUniforms({isStroke: true, opacity: strokeOpacity})\n        .draw();\n    }\n  }\n}\n\nEnhancedColumnLayer.layerName = 'EnhancedColumnLayer';\n\nexport default EnhancedColumnLayer;\n"],"mappings":"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","ignoreList":[]}
;