kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
195 lines (152 loc) • 18.3 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.gridVisConfigs = undefined;
var _toConsumableArray2 = require('babel-runtime/helpers/toConsumableArray');
var _toConsumableArray3 = _interopRequireDefault(_toConsumableArray2);
var _extends2 = require('babel-runtime/helpers/extends');
var _extends3 = _interopRequireDefault(_extends2);
var _classCallCheck2 = require('babel-runtime/helpers/classCallCheck');
var _classCallCheck3 = _interopRequireDefault(_classCallCheck2);
var _createClass2 = require('babel-runtime/helpers/createClass');
var _createClass3 = _interopRequireDefault(_createClass2);
var _possibleConstructorReturn2 = require('babel-runtime/helpers/possibleConstructorReturn');
var _possibleConstructorReturn3 = _interopRequireDefault(_possibleConstructorReturn2);
var _get2 = require('babel-runtime/helpers/get');
var _get3 = _interopRequireDefault(_get2);
var _inherits2 = require('babel-runtime/helpers/inherits');
var _inherits3 = _interopRequireDefault(_inherits2);
var _deck = require('deck.gl');
var _aggregationLayer = require('../aggregation-layer');
var _aggregationLayer2 = _interopRequireDefault(_aggregationLayer);
var _enhancedGridLayer = require('../../deckgl-layers/grid-layer/enhanced-grid-layer');
var _enhancedGridLayer2 = _interopRequireDefault(_enhancedGridLayer);
var _gridUtils = require('./grid-utils');
var _gridLayerIcon = require('./grid-layer-icon');
var _gridLayerIcon2 = _interopRequireDefault(_gridLayerIcon);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
var gridVisConfigs = exports.gridVisConfigs = {
opacity: 'opacity',
worldUnitSize: 'worldUnitSize',
colorRange: 'colorRange',
coverage: 'coverage',
sizeRange: 'elevationRange',
percentile: 'percentile',
elevationPercentile: 'elevationPercentile',
elevationScale: 'elevationScale',
'hi-precision': 'hi-precision',
colorAggregation: 'aggregation',
sizeAggregation: 'sizeAggregation',
enable3d: 'enable3d'
}; // Copyright (c) 2018 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
var GridLayer = function (_AggregationLayer) {
(0, _inherits3.default)(GridLayer, _AggregationLayer);
function GridLayer(props) {
(0, _classCallCheck3.default)(this, GridLayer);
var _this = (0, _possibleConstructorReturn3.default)(this, (GridLayer.__proto__ || Object.getPrototypeOf(GridLayer)).call(this, props));
_this.registerVisConfig(gridVisConfigs);
_this.visConfigSettings.worldUnitSize.label = 'Grid Size (km)';
return _this;
}
(0, _createClass3.default)(GridLayer, [{
key: 'formatLayerData',
value: function formatLayerData(_, allData, filteredIndex, oldLayerData) {
var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {};
var formattedData = (0, _get3.default)(GridLayer.prototype.__proto__ || Object.getPrototypeOf(GridLayer.prototype), 'formatLayerData', this).call(this, _, allData, filteredIndex, oldLayerData, opt);
var getPosition = formattedData.getPosition,
data = formattedData.data;
// TODO: fix this in deck.gl layer
var cleaned = data.filter(function (d) {
var pos = getPosition(d);
return pos.every(Number.isFinite);
});
// All data processing is done in deck.gl layer
return (0, _extends3.default)({}, formattedData, {
data: cleaned
});
}
}, {
key: 'renderLayer',
value: function renderLayer(_ref) {
var data = _ref.data,
idx = _ref.idx,
objectHovered = _ref.objectHovered,
mapState = _ref.mapState,
interaction = _ref.interaction,
layerCallbacks = _ref.layerCallbacks;
var zoomFactor = this.getZoomFactor(mapState);
var eleZoomFactor = this.getElevationZoomFactor(mapState);
var visConfig = this.config.visConfig;
var cellSize = visConfig.worldUnitSize * 1000;
return [new _enhancedGridLayer2.default((0, _extends3.default)({}, data, {
id: this.id,
idx: idx,
cellSize: cellSize,
coverage: visConfig.coverage,
// highlight
autoHighlight: visConfig.enable3d,
// color
colorRange: this.getColorRange(visConfig.colorRange),
colorScale: this.config.colorScale,
opacity: visConfig.opacity,
upperPercentile: visConfig.percentile[1],
lowerPercentile: visConfig.percentile[0],
// elevation
extruded: visConfig.enable3d,
elevationScale: visConfig.elevationScale * eleZoomFactor,
elevationLowerPercentile: visConfig.elevationPercentile[0],
elevationUpperPercentile: visConfig.elevationPercentile[1],
// parameters
parameters: { depthTest: Boolean(visConfig.enable3d || mapState.dragRotate) },
// render
fp64: visConfig['hi-precision'],
pickable: true,
lightSettings: this.meta && this.meta.lightSettings,
// callbacks
onSetColorDomain: layerCallbacks.onSetLayerDomain
}))].concat((0, _toConsumableArray3.default)(this.isLayerHovered(objectHovered) && !visConfig.enable3d ? [new _deck.GeoJsonLayer({
id: this.id + '-hovered',
data: [(0, _gridUtils.pointToPolygonGeo)({
object: objectHovered.object,
cellSize: cellSize,
coverage: visConfig.coverage,
properties: { lineColor: this.config.highlightColor },
mapState: mapState
})],
lineWidthScale: 8 * zoomFactor
})] : []));
}
}, {
key: 'type',
get: function get() {
return 'grid';
}
}, {
key: 'layerIcon',
get: function get() {
return _gridLayerIcon2.default;
}
}]);
return GridLayer;
}(_aggregationLayer2.default);
exports.default = GridLayer;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/grid-layer/grid-layer.js"],"names":["gridVisConfigs","opacity","worldUnitSize","colorRange","coverage","sizeRange","percentile","elevationPercentile","elevationScale","colorAggregation","sizeAggregation","enable3d","GridLayer","props","registerVisConfig","visConfigSettings","label","_","allData","filteredIndex","oldLayerData","opt","formattedData","getPosition","data","cleaned","filter","pos","d","every","Number","isFinite","idx","objectHovered","mapState","interaction","layerCallbacks","zoomFactor","getZoomFactor","eleZoomFactor","getElevationZoomFactor","visConfig","config","cellSize","EnhancedGridLayer","id","autoHighlight","getColorRange","colorScale","upperPercentile","lowerPercentile","extruded","elevationLowerPercentile","elevationUpperPercentile","parameters","depthTest","Boolean","dragRotate","fp64","pickable","lightSettings","meta","onSetColorDomain","onSetLayerDomain","isLayerHovered","GeoJsonLayer","object","properties","lineColor","highlightColor","lineWidthScale","GridLayerIcon","AggregationLayer"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA;;AACA;;;;AACA;;;;AACA;;AACA;;;;;;AAEO,IAAMA,0CAAiB;AAC5BC,WAAS,SADmB;AAE5BC,iBAAe,eAFa;AAG5BC,cAAY,YAHgB;AAI5BC,YAAU,UAJkB;AAK5BC,aAAW,gBALiB;AAM5BC,cAAY,YANgB;AAO5BC,uBAAqB,qBAPO;AAQ5BC,kBAAgB,gBARY;AAS5B,kBAAgB,cATY;AAU5BC,oBAAkB,aAVU;AAW5BC,mBAAiB,iBAXW;AAY5BC,YAAU;AAZkB,CAAvB,C,CA1BP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;IAuBqBC,S;;;AACnB,qBAAYC,KAAZ,EAAmB;AAAA;;AAAA,oIACXA,KADW;;AAGjB,UAAKC,iBAAL,CAAuBd,cAAvB;AACA,UAAKe,iBAAL,CAAuBb,aAAvB,CAAqCc,KAArC,GAA6C,gBAA7C;AAJiB;AAKlB;;;;oCAUeC,C,EAAGC,O,EAASC,a,EAAeC,Y,EAAwB;AAAA,UAAVC,GAAU,uEAAJ,EAAI;;AACjE,UAAMC,oJACJL,CADI,EAEJC,OAFI,EAGJC,aAHI,EAIJC,YAJI,EAKJC,GALI,CAAN;;AADiE,UAS1DE,WAT0D,GASrCD,aATqC,CAS1DC,WAT0D;AAAA,UAS7CC,IAT6C,GASrCF,aATqC,CAS7CE,IAT6C;;AAWjE;;AACA,UAAMC,UAAUD,KAAKE,MAAL,CAAY,aAAK;AAC/B,YAAMC,MAAMJ,YAAYK,CAAZ,CAAZ;AACA,eAAOD,IAAIE,KAAJ,CAAUC,OAAOC,QAAjB,CAAP;AACD,OAHe,CAAhB;;AAKA;AACA,wCACKT,aADL;AAEEE,cAAMC;AAFR;AAID;;;sCASE;AAAA,UANDD,IAMC,QANDA,IAMC;AAAA,UALDQ,GAKC,QALDA,GAKC;AAAA,UAJDC,aAIC,QAJDA,aAIC;AAAA,UAHDC,QAGC,QAHDA,QAGC;AAAA,UAFDC,WAEC,QAFDA,WAEC;AAAA,UADDC,cACC,QADDA,cACC;;AACD,UAAMC,aAAa,KAAKC,aAAL,CAAmBJ,QAAnB,CAAnB;AACA,UAAMK,gBAAgB,KAAKC,sBAAL,CAA4BN,QAA5B,CAAtB;AAFC,UAGMO,SAHN,GAGmB,KAAKC,MAHxB,CAGMD,SAHN;;AAID,UAAME,WAAWF,UAAUvC,aAAV,GAA0B,IAA3C;;AAEA,cACE,IAAI0C,2BAAJ,4BACKpB,IADL;AAEEqB,YAAI,KAAKA,EAFX;AAGEb,gBAHF;AAIEW,0BAJF;AAKEvC,kBAAUqC,UAAUrC,QALtB;AAME;AACA0C,uBAAeL,UAAU9B,QAP3B;;AASE;AACAR,oBAAY,KAAK4C,aAAL,CAAmBN,UAAUtC,UAA7B,CAVd;AAWE6C,oBAAY,KAAKN,MAAL,CAAYM,UAX1B;AAYE/C,iBAASwC,UAAUxC,OAZrB;AAaEgD,yBAAiBR,UAAUnC,UAAV,CAAqB,CAArB,CAbnB;AAcE4C,yBAAiBT,UAAUnC,UAAV,CAAqB,CAArB,CAdnB;;AAgBE;AACA6C,kBAAUV,UAAU9B,QAjBtB;AAkBEH,wBAAgBiC,UAAUjC,cAAV,GAA2B+B,aAlB7C;AAmBEa,kCAA0BX,UAAUlC,mBAAV,CAA8B,CAA9B,CAnB5B;AAoBE8C,kCAA0BZ,UAAUlC,mBAAV,CAA8B,CAA9B,CApB5B;AAqBE;AACA+C,oBAAY,EAACC,WAAWC,QAAQf,UAAU9B,QAAV,IAAsBuB,SAASuB,UAAvC,CAAZ,EAtBd;;AAwBE;AACAC,cAAMjB,UAAU,cAAV,CAzBR;AA0BEkB,kBAAU,IA1BZ;AA2BEC,uBAAe,KAAKC,IAAL,IAAa,KAAKA,IAAL,CAAUD,aA3BxC;;AA6BE;AACAE,0BAAkB1B,eAAe2B;AA9BnC,SADF,0CAmCM,KAAKC,cAAL,CAAoB/B,aAApB,KAAsC,CAACQ,UAAU9B,QAAjD,GACA,CACE,IAAIsD,kBAAJ,CAAiB;AACfpB,YAAO,KAAKA,EAAZ,aADe;AAEfrB,cAAM,CACJ,kCAAkB;AAChB0C,kBAAQjC,cAAciC,MADN;AAEhBvB,4BAFgB;AAGhBvC,oBAAUqC,UAAUrC,QAHJ;AAIhB+D,sBAAY,EAACC,WAAW,KAAK1B,MAAL,CAAY2B,cAAxB,EAJI;AAKhBnC;AALgB,SAAlB,CADI,CAFS;AAWfoC,wBAAgB,IAAIjC;AAXL,OAAjB,CADF,CADA,GAgBA,EAnDN;AAqDD;;;wBAlGU;AACT,aAAO,MAAP;AACD;;;wBAEe;AACd,aAAOkC,uBAAP;AACD;;;EAdoCC,0B;;kBAAlB5D,S","file":"grid-layer.js","sourcesContent":["// Copyright (c) 2018 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport {GeoJsonLayer} from 'deck.gl';\nimport AggregationLayer from '../aggregation-layer';\nimport EnhancedGridLayer from 'deckgl-layers/grid-layer/enhanced-grid-layer';\nimport {pointToPolygonGeo} from './grid-utils';\nimport GridLayerIcon from './grid-layer-icon';\n\nexport const gridVisConfigs = {\n  opacity: 'opacity',\n  worldUnitSize: 'worldUnitSize',\n  colorRange: 'colorRange',\n  coverage: 'coverage',\n  sizeRange: 'elevationRange',\n  percentile: 'percentile',\n  elevationPercentile: 'elevationPercentile',\n  elevationScale: 'elevationScale',\n  'hi-precision': 'hi-precision',\n  colorAggregation: 'aggregation',\n  sizeAggregation: 'sizeAggregation',\n  enable3d: 'enable3d'\n};\n\nexport default class GridLayer extends AggregationLayer {\n  constructor(props) {\n    super(props);\n\n    this.registerVisConfig(gridVisConfigs);\n    this.visConfigSettings.worldUnitSize.label = 'Grid Size (km)';\n  }\n\n  get type() {\n    return 'grid';\n  }\n\n  get layerIcon() {\n    return GridLayerIcon;\n  }\n\n  formatLayerData(_, allData, filteredIndex, oldLayerData, opt = {}) {\n    const formattedData = super.formatLayerData(\n      _,\n      allData,\n      filteredIndex,\n      oldLayerData,\n      opt\n    );\n\n    const {getPosition, data} = formattedData;\n\n    // TODO: fix this in deck.gl layer\n    const cleaned = data.filter(d => {\n      const pos = getPosition(d);\n      return pos.every(Number.isFinite);\n    });\n\n    // All data processing is done in deck.gl layer\n    return {\n      ...formattedData,\n      data: cleaned\n    };\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    mapState,\n    interaction,\n    layerCallbacks\n  }) {\n    const zoomFactor = this.getZoomFactor(mapState);\n    const eleZoomFactor = this.getElevationZoomFactor(mapState);\n    const {visConfig} = this.config;\n    const cellSize = visConfig.worldUnitSize * 1000;\n\n    return [\n      new EnhancedGridLayer({\n        ...data,\n        id: this.id,\n        idx,\n        cellSize,\n        coverage: visConfig.coverage,\n        // highlight\n        autoHighlight: visConfig.enable3d,\n\n        // color\n        colorRange: this.getColorRange(visConfig.colorRange),\n        colorScale: this.config.colorScale,\n        opacity: visConfig.opacity,\n        upperPercentile: visConfig.percentile[1],\n        lowerPercentile: visConfig.percentile[0],\n\n        // elevation\n        extruded: visConfig.enable3d,\n        elevationScale: visConfig.elevationScale * eleZoomFactor,\n        elevationLowerPercentile: visConfig.elevationPercentile[0],\n        elevationUpperPercentile: visConfig.elevationPercentile[1],\n        // parameters\n        parameters: {depthTest: Boolean(visConfig.enable3d || mapState.dragRotate)},\n\n        // render\n        fp64: visConfig['hi-precision'],\n        pickable: true,\n        lightSettings: this.meta && this.meta.lightSettings,\n\n        // callbacks\n        onSetColorDomain: layerCallbacks.onSetLayerDomain\n      }),\n\n      // render an outline of each cell if not extruded\n      ...(this.isLayerHovered(objectHovered) && !visConfig.enable3d\n        ? [\n            new GeoJsonLayer({\n              id: `${this.id}-hovered`,\n              data: [\n                pointToPolygonGeo({\n                  object: objectHovered.object,\n                  cellSize,\n                  coverage: visConfig.coverage,\n                  properties: {lineColor: this.config.highlightColor},\n                  mapState\n                })\n              ],\n              lineWidthScale: 8 * zoomFactor\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}
;