UNPKG

kepler.gl

Version:

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

386 lines (315 loc) 35.4 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.HexagonIdVisConfigs = exports.hexIdResolver = exports.hexIdAccessor = exports.hexIdRequiredColumns = exports.HEXAGON_ID_FIELDS = 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 _lodash = require('lodash.memoize'); var _lodash2 = _interopRequireDefault(_lodash); var _baseLayer = require('../base-layer'); var _baseLayer2 = _interopRequireDefault(_baseLayer); var _deck = require('deck.gl'); var _h3HexagonCellLayer = require('../../deckgl-layers/h3-hexagon-cell-layer/h3-hexagon-cell-layer'); var _h3HexagonCellLayer2 = _interopRequireDefault(_h3HexagonCellLayer); var _h3Utils = require('./h3-utils'); var _h3HexagonLayerIcon = require('./h3-hexagon-layer-icon'); var _h3HexagonLayerIcon2 = _interopRequireDefault(_h3HexagonLayerIcon); var _defaultSettings = require('../../constants/default-settings'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } var HEXAGON_ID_FIELDS = exports.HEXAGON_ID_FIELDS = { hex_id: ['hex_id', 'hexagon_id', 'h3_id'] }; // 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 hexIdRequiredColumns = exports.hexIdRequiredColumns = ['hex_id']; var hexIdAccessor = exports.hexIdAccessor = function hexIdAccessor(_ref) { var hex_id = _ref.hex_id; return function (d) { return d[hex_id.fieldIdx]; }; }; var hexIdResolver = exports.hexIdResolver = function hexIdResolver(_ref2) { var hex_id = _ref2.hex_id; return hex_id.fieldIdx; }; var HexagonIdVisConfigs = exports.HexagonIdVisConfigs = { opacity: 'opacity', colorRange: 'colorRange', coverage: 'coverage', sizeRange: 'elevationRange', coverageRange: 'coverageRange', elevationScale: 'elevationScale', 'hi-precision': 'hi-precision' }; function hexToRgb(hex) { var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); var r = parseInt(result[1], 16); var g = parseInt(result[2], 16); var b = parseInt(result[3], 16); return [r, g, b]; } var HexagonIdLayer = function (_Layer) { (0, _inherits3.default)(HexagonIdLayer, _Layer); function HexagonIdLayer(props) { (0, _classCallCheck3.default)(this, HexagonIdLayer); var _this = (0, _possibleConstructorReturn3.default)(this, (HexagonIdLayer.__proto__ || Object.getPrototypeOf(HexagonIdLayer)).call(this, props)); _this.registerVisConfig(HexagonIdVisConfigs); _this.getHexId = (0, _lodash2.default)(hexIdAccessor, hexIdResolver); return _this; } (0, _createClass3.default)(HexagonIdLayer, [{ key: 'getDefaultLayerConfig', value: function getDefaultLayerConfig() { var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; return (0, _extends3.default)({}, (0, _get3.default)(HexagonIdLayer.prototype.__proto__ || Object.getPrototypeOf(HexagonIdLayer.prototype), 'getDefaultLayerConfig', this).call(this, props), { // add height visual channel coverageField: null, coverageDomain: [0, 1], coverageScale: 'linear' }); } }, { key: 'formatLayerData', value: function formatLayerData(_, allData, filteredIndex, oldLayerData) { var _this2 = this; var opt = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : {}; var _config = this.config, colorScale = _config.colorScale, colorDomain = _config.colorDomain, colorField = _config.colorField, color = _config.color, columns = _config.columns, sizeField = _config.sizeField, sizeScale = _config.sizeScale, sizeDomain = _config.sizeDomain, coverageField = _config.coverageField, coverageScale = _config.coverageScale, coverageDomain = _config.coverageDomain, _config$visConfig = _config.visConfig, sizeRange = _config$visConfig.sizeRange, colorRange = _config$visConfig.colorRange, coverageRange = _config$visConfig.coverageRange; // color var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(function (c) { return hexToRgb(c); })); // height var sScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange); // coverage var coScale = coverageField && this.getVisChannelScale(coverageScale, coverageDomain, coverageRange); var getHexId = this.getHexId(columns); if (!oldLayerData || oldLayerData.getHexId !== getHexId) { this.updateLayerMeta(allData, getHexId); } var data = void 0; if (oldLayerData && oldLayerData.data && opt.sameData && oldLayerData.getHexId === getHexId) { data = oldLayerData.data; } else { data = filteredIndex.reduce(function (accu, index, i) { var id = getHexId(allData[index]); var centroid = _this2.dataToFeature.centroids[index]; if (centroid) { accu.push({ // keep a reference to the original data index index: i, data: allData[index], id: id, centroid: centroid }); } return accu; }, []); } var getElevation = sScale ? function (d) { return _this2.getEncodedChannelValue(sScale, d.data, sizeField, 0); } : 0; var getColor = cScale ? function (d) { return _this2.getEncodedChannelValue(cScale, d.data, colorField); } : color; var getCoverage = coScale ? function (d) { return _this2.getEncodedChannelValue(coScale, d.data, coverageField, 0); } : 1; // const layerData = { return { data: data, getElevation: getElevation, getColor: getColor, getHexId: getHexId, getCoverage: getCoverage, hexagonVertices: this.dataToFeature.hexagonVertices, hexagonCenter: this.dataToFeature.hexagonCenter }; } }, { key: 'updateLayerMeta', value: function updateLayerMeta(allData, getHexId) { var hexagonVertices = void 0; var hexagonCenter = void 0; var centroids = {}; allData.forEach(function (d, index) { var id = getHexId(d); if (typeof id !== 'string' || !id.length) { return; } // find hexagonVertices // only need 1 instance of hexagonVertices if (!hexagonVertices) { hexagonVertices = id && (0, _h3Utils.getVertices)({ id: id }); hexagonCenter = id && (0, _h3Utils.getCentroid)({ id: id }); } // save a reference of centroids to dataToFeature // so we don't have to re calculate it again centroids[index] = (0, _h3Utils.getCentroid)({ id: id }); }); var bounds = this.getPointsBounds(Object.values(centroids), function (d) { return d; }); var lightSettings = this.getLightSettingsFromBounds(bounds); this.dataToFeature = { hexagonVertices: hexagonVertices, hexagonCenter: hexagonCenter, centroids: centroids }; this.updateMeta({ bounds: bounds, lightSettings: lightSettings }); } }, { key: 'renderLayer', value: function renderLayer(_ref3) { var data = _ref3.data, idx = _ref3.idx, layerInteraction = _ref3.layerInteraction, objectHovered = _ref3.objectHovered, mapState = _ref3.mapState, interactionConfig = _ref3.interactionConfig; var zoomFactor = this.getZoomFactor(mapState); var eleZoomFactor = this.getElevationZoomFactor(mapState); var config = this.config, meta = this.meta; var visConfig = config.visConfig; var updateTriggers = { getColor: { color: config.color, colorField: config.colorField, colorRange: config.visConfig.colorRange, colorScale: config.colorScale }, getElevation: { sizeField: config.sizeField, sizeRange: config.visConfig.sizeRange }, getCoverage: { coverageField: config.coverageField, coverageRange: config.visConfig.coverageRange } }; return [new _h3HexagonCellLayer2.default((0, _extends3.default)({}, layerInteraction, data, { id: this.id, idx: idx, pickable: true, // coverage coverage: config.coverageField ? 1 : visConfig.coverage, // parameters parameters: { depthTest: Boolean(config.sizeField || mapState.dragRotate) }, // highlight autoHighlight: Boolean(config.sizeField), // elevation extruded: Boolean(config.sizeField), elevationScale: visConfig.elevationScale * eleZoomFactor, // color opacity: visConfig.opacity, // render lightSettings: meta.lightSettings, updateTriggers: updateTriggers }))].concat((0, _toConsumableArray3.default)(this.isLayerHovered(objectHovered) && !config.sizeField ? [new _deck.GeoJsonLayer({ id: this.id + '-hovered', data: [(0, _h3Utils.idToPolygonGeo)(objectHovered, { lineColor: config.highlightColor })], lineWidthScale: 8 * zoomFactor })] : [])); } }, { key: 'type', get: function get() { return 'hexagonId'; } }, { key: 'name', get: function get() { return 'H3'; } }, { key: 'requiredLayerColumns', get: function get() { return hexIdRequiredColumns; } }, { key: 'layerIcon', get: function get() { // use hexagon layer icon for now return _h3HexagonLayerIcon2.default; } }, { key: 'visualChannels', get: function get() { return (0, _extends3.default)({}, (0, _get3.default)(HexagonIdLayer.prototype.__proto__ || Object.getPrototypeOf(HexagonIdLayer.prototype), 'visualChannels', this), { size: (0, _extends3.default)({}, (0, _get3.default)(HexagonIdLayer.prototype.__proto__ || Object.getPrototypeOf(HexagonIdLayer.prototype), 'visualChannels', this).size, { property: 'height' }), coverage: { property: 'coverage', field: 'coverageField', scale: 'coverageScale', domain: 'coverageDomain', range: 'coverageRange', key: 'coverage', channelScaleType: _defaultSettings.CHANNEL_SCALES.radius } }); } }], [{ key: 'findDefaultLayerProps', value: function findDefaultLayerProps(_ref4) { var fields = _ref4.fields; var foundColumns = this.findDefaultColumnField(HEXAGON_ID_FIELDS, fields); if (!foundColumns || !foundColumns.length) { return null; } return foundColumns.map(function (columns) { return { isVisible: true, label: 'H3 Hexagon', columns: columns }; }); } }]); return HexagonIdLayer; }(_baseLayer2.default); exports.default = HexagonIdLayer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/h3-hexagon-layer/h3-hexagon-layer.js"],"names":["HEXAGON_ID_FIELDS","hex_id","hexIdRequiredColumns","hexIdAccessor","d","fieldIdx","hexIdResolver","HexagonIdVisConfigs","opacity","colorRange","coverage","sizeRange","coverageRange","elevationScale","hexToRgb","hex","result","exec","r","parseInt","g","b","HexagonIdLayer","props","registerVisConfig","getHexId","coverageField","coverageDomain","coverageScale","_","allData","filteredIndex","oldLayerData","opt","config","colorScale","colorDomain","colorField","color","columns","sizeField","sizeScale","sizeDomain","visConfig","cScale","getVisChannelScale","colors","map","c","sScale","coScale","updateLayerMeta","data","sameData","reduce","accu","index","i","id","centroid","dataToFeature","centroids","push","getElevation","getEncodedChannelValue","getColor","getCoverage","hexagonVertices","hexagonCenter","forEach","length","bounds","getPointsBounds","Object","values","lightSettings","getLightSettingsFromBounds","updateMeta","idx","layerInteraction","objectHovered","mapState","interactionConfig","zoomFactor","getZoomFactor","eleZoomFactor","getElevationZoomFactor","meta","updateTriggers","H3HexagonCellLayer","pickable","parameters","depthTest","Boolean","dragRotate","autoHighlight","extruded","isLayerHovered","GeoJsonLayer","lineColor","highlightColor","lineWidthScale","H3HexagonLayerIcon","size","property","field","scale","domain","range","key","channelScaleType","CHANNEL_SCALES","radius","fields","foundColumns","findDefaultColumnField","isVisible","label","Layer"],"mappings":"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","file":"h3-hexagon-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 memoize from 'lodash.memoize';\n\nimport Layer from '../base-layer';\nimport {GeoJsonLayer} from 'deck.gl';\nimport H3HexagonCellLayer from 'deckgl-layers/h3-hexagon-cell-layer/h3-hexagon-cell-layer';\nimport {getVertices, getCentroid, idToPolygonGeo} from './h3-utils';\nimport H3HexagonLayerIcon from './h3-hexagon-layer-icon';\nimport {CHANNEL_SCALES} from 'constants/default-settings';\n\nexport const HEXAGON_ID_FIELDS = {\n  hex_id: ['hex_id', 'hexagon_id', 'h3_id']\n};\n\nexport const hexIdRequiredColumns = ['hex_id'];\nexport const hexIdAccessor = ({hex_id}) => d => d[hex_id.fieldIdx];\nexport const hexIdResolver = ({hex_id}) => hex_id.fieldIdx;\n\nexport const HexagonIdVisConfigs = {\n  opacity: 'opacity',\n  colorRange: 'colorRange',\n  coverage: 'coverage',\n  sizeRange: 'elevationRange',\n  coverageRange: 'coverageRange',\n  elevationScale: 'elevationScale',\n  'hi-precision': 'hi-precision'\n};\n\nfunction hexToRgb(hex) {\n  const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n\n  const r = parseInt(result[1], 16);\n  const g = parseInt(result[2], 16);\n  const b = parseInt(result[3], 16);\n\n  return [r, g, b];\n}\n\nexport default class HexagonIdLayer extends Layer {\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(HexagonIdVisConfigs);\n    this.getHexId = memoize(hexIdAccessor, hexIdResolver);\n  }\n\n  get type() {\n    return 'hexagonId';\n  }\n\n  get name() {\n    return 'H3';\n  }\n\n  get requiredLayerColumns() {\n    return hexIdRequiredColumns;\n  }\n\n  get layerIcon() {\n    // use hexagon layer icon for now\n    return H3HexagonLayerIcon;\n  }\n\n  get visualChannels() {\n    return {\n      ...super.visualChannels,\n      size: {\n        ...super.visualChannels.size,\n        property: 'height'\n      },\n      coverage: {\n        property: 'coverage',\n        field: 'coverageField',\n        scale: 'coverageScale',\n        domain: 'coverageDomain',\n        range: 'coverageRange',\n        key: 'coverage',\n        channelScaleType: CHANNEL_SCALES.radius\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fields}) {\n    const foundColumns = this.findDefaultColumnField(HEXAGON_ID_FIELDS, fields);\n    if (!foundColumns || !foundColumns.length) {\n      return null;\n    }\n\n    return foundColumns.map(columns => ({\n      isVisible: true,\n      label: 'H3 Hexagon',\n      columns\n    }));\n  }\n\n  getDefaultLayerConfig(props = {}) {\n    return {\n      ...super.getDefaultLayerConfig(props),\n\n      // add height visual channel\n      coverageField: null,\n      coverageDomain: [0, 1],\n      coverageScale: 'linear'\n    };\n  }\n\n  formatLayerData(_, allData, filteredIndex, oldLayerData, opt = {}) {\n    const {\n      colorScale,\n      colorDomain,\n      colorField,\n      color,\n      columns,\n      sizeField,\n      sizeScale,\n      sizeDomain,\n      coverageField,\n      coverageScale,\n      coverageDomain,\n      visConfig: {sizeRange, colorRange, coverageRange}\n    } = this.config;\n\n    // color\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(\n        colorScale,\n        colorDomain,\n        colorRange.colors.map(c => hexToRgb(c))\n      );\n\n    // height\n    const sScale =\n      sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);\n\n    // coverage\n    const coScale =\n      coverageField && this.getVisChannelScale(coverageScale, coverageDomain, coverageRange);\n\n    const getHexId = this.getHexId(columns);\n\n    if (!oldLayerData || oldLayerData.getHexId !== getHexId) {\n      this.updateLayerMeta(allData, getHexId);\n    }\n\n    let data;\n    if (\n      oldLayerData &&\n      oldLayerData.data &&\n      opt.sameData &&\n      oldLayerData.getHexId === getHexId\n    ) {\n      data = oldLayerData.data;\n    } else {\n      data = filteredIndex.reduce((accu, index, i) => {\n        const id = getHexId(allData[index]);\n        const centroid = this.dataToFeature.centroids[index];\n\n        if (centroid) {\n          accu.push({\n            // keep a reference to the original data index\n            index: i,\n            data: allData[index],\n            id,\n            centroid\n          });\n        }\n\n        return accu;\n      }, []);\n    }\n\n    const getElevation = sScale ? d =>\n      this.getEncodedChannelValue(sScale, d.data, sizeField, 0) : 0;\n\n    const getColor = cScale ? d =>\n      this.getEncodedChannelValue(cScale, d.data, colorField) : color;\n\n    const getCoverage = coScale ? d =>\n      this.getEncodedChannelValue(coScale, d.data, coverageField, 0) : 1;\n\n    // const layerData = {\n    return {\n      data,\n      getElevation,\n      getColor,\n      getHexId,\n      getCoverage,\n      hexagonVertices: this.dataToFeature.hexagonVertices,\n      hexagonCenter: this.dataToFeature.hexagonCenter\n    };\n  }\n\n  updateLayerMeta(allData, getHexId) {\n    let hexagonVertices;\n    let hexagonCenter;\n    const centroids = {};\n\n    allData.forEach((d, index) => {\n      const id = getHexId(d);\n      if (typeof id !== 'string' || !id.length) {\n        return;\n      }\n      // find hexagonVertices\n      // only need 1 instance of hexagonVertices\n      if (!hexagonVertices) {\n        hexagonVertices = id && getVertices({id});\n        hexagonCenter = id && getCentroid({id})\n      }\n\n      // save a reference of centroids to dataToFeature\n      // so we don't have to re calculate it again\n      centroids[index] = getCentroid({id});\n    });\n\n    const bounds = this.getPointsBounds(Object.values(centroids), d => d);\n    const lightSettings = this.getLightSettingsFromBounds(bounds);\n\n    this.dataToFeature = {hexagonVertices, hexagonCenter, centroids};\n    this.updateMeta({bounds, lightSettings});\n  }\n\n  renderLayer({\n    data,\n    idx,\n    layerInteraction,\n    objectHovered,\n    mapState,\n    interactionConfig\n  }) {\n    const zoomFactor = this.getZoomFactor(mapState);\n    const eleZoomFactor = this.getElevationZoomFactor(mapState);\n    const {config, meta} = this;\n    const {visConfig} = config;\n\n    const updateTriggers = {\n      getColor: {\n        color: config.color,\n        colorField: config.colorField,\n        colorRange: config.visConfig.colorRange,\n        colorScale: config.colorScale\n      },\n      getElevation: {\n        sizeField: config.sizeField,\n        sizeRange: config.visConfig.sizeRange\n      },\n      getCoverage: {\n        coverageField: config.coverageField,\n        coverageRange: config.visConfig.coverageRange\n      }\n    };\n\n    return [\n      new H3HexagonCellLayer({\n        ...layerInteraction,\n        ...data,\n        id: this.id,\n        idx,\n        pickable: true,\n\n        // coverage\n        coverage: config.coverageField ? 1 : visConfig.coverage,\n\n        // parameters\n        parameters: {depthTest: Boolean(config.sizeField || mapState.dragRotate)},\n\n        // highlight\n        autoHighlight: Boolean(config.sizeField),\n\n        // elevation\n        extruded: Boolean(config.sizeField),\n        elevationScale: visConfig.elevationScale * eleZoomFactor,\n\n        // color\n        opacity: visConfig.opacity,\n\n        // render\n        lightSettings: meta.lightSettings,\n        updateTriggers\n      }),\n      ...(this.isLayerHovered(objectHovered) && !config.sizeField\n        ? [\n            new GeoJsonLayer({\n              id: `${this.id}-hovered`,\n              data: [\n                idToPolygonGeo(objectHovered, {\n                  lineColor: config.highlightColor\n                })\n              ],\n              lineWidthScale: 8 * zoomFactor\n            })\n          ]\n        : [])\n    ];\n  }\n}\n"]}