UNPKG

kepler.gl

Version:

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

328 lines (266 loc) 30.5 kB
'use strict'; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = exports.arctVisConfigs = exports.arcRequiredColumns = exports.arcPosResolver = exports.arcPosAccessor = undefined; 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 _arcBrushingLayer = require('../../deckgl-layers/arc-brushing-layer/arc-brushing-layer'); var _arcBrushingLayer2 = _interopRequireDefault(_arcBrushingLayer); var _colorUtils = require('../../utils/color-utils'); var _arcLayerIcon = require('./arc-layer-icon'); var _arcLayerIcon2 = _interopRequireDefault(_arcLayerIcon); var _defaultSettings = require('../../constants/default-settings'); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } // 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 arcPosAccessor = exports.arcPosAccessor = function arcPosAccessor(_ref) { var lat0 = _ref.lat0, lng0 = _ref.lng0, lat1 = _ref.lat1, lng1 = _ref.lng1; return function (d) { return [d.data[lng0.fieldIdx], d.data[lat0.fieldIdx], 0, d.data[lng1.fieldIdx], d.data[lat1.fieldIdx], 0]; }; }; var arcPosResolver = exports.arcPosResolver = function arcPosResolver(_ref2) { var lat0 = _ref2.lat0, lng0 = _ref2.lng0, lat1 = _ref2.lat1, lng1 = _ref2.lng1; return lat0.fieldIdx + '-' + lng0.fieldIdx + '-' + lat1.fieldIdx + '-' + lat1.fieldIdx + '}'; }; var arcRequiredColumns = exports.arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1']; var arctVisConfigs = exports.arctVisConfigs = { opacity: 'opacity', thickness: 'thickness', colorRange: 'colorRange', sizeRange: 'strokeWidthRange', targetColor: 'targetColor', 'hi-precision': 'hi-precision' }; var ArcLayer = function (_Layer) { (0, _inherits3.default)(ArcLayer, _Layer); function ArcLayer(props) { (0, _classCallCheck3.default)(this, ArcLayer); var _this = (0, _possibleConstructorReturn3.default)(this, (ArcLayer.__proto__ || Object.getPrototypeOf(ArcLayer)).call(this, props)); _this.registerVisConfig(arctVisConfigs); _this.getPosition = (0, _lodash2.default)(arcPosAccessor, arcPosResolver); return _this; } (0, _createClass3.default)(ArcLayer, [{ 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, _config$visConfig = _config.visConfig, sizeRange = _config$visConfig.sizeRange, colorRange = _config$visConfig.colorRange, targetColor = _config$visConfig.targetColor; // arc color var cScale = colorField && this.getVisChannelScale(colorScale, colorDomain, colorRange.colors.map(_colorUtils.hexToRgb)); // arc thickness var sScale = sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange); var getPosition = this.getPosition(columns); if (!oldLayerData || oldLayerData.getPosition !== getPosition) { this.updateLayerMeta(allData, getPosition); } var data = void 0; if (oldLayerData && oldLayerData.data && opt.sameData && oldLayerData.getPosition === getPosition) { data = oldLayerData.data; } else { data = filteredIndex.reduce(function (accu, index) { var pos = getPosition({ data: allData[index] }); // if doesn't have point lat or lng, do not add the arc // deck.gl can't handle position == null if (!pos.every(Number.isFinite)) { return accu; } accu.push({ index: index, sourcePosition: [pos[0], pos[1], pos[2]], targetPosition: [pos[3], pos[4], pos[5]], data: allData[index] }); return accu; }, []); } var getStrokeWidth = sScale ? function (d) { return _this2.getEncodedChannelValue(sScale, d.data, sizeField, 0); } : 1; var getColor = cScale ? function (d) { return _this2.getEncodedChannelValue(cScale, d.data, colorField); } : color; var getTargetColor = cScale ? function (d) { return _this2.getEncodedChannelValue(cScale, d.data, colorField); } : targetColor || color; return { data: data, getColor: getColor, getSourceColor: getColor, getTargetColor: getTargetColor, getStrokeWidth: getStrokeWidth }; } }, { key: 'updateLayerMeta', value: function updateLayerMeta(allData, getPosition) { // get bounds from arcs var sBounds = this.getPointsBounds(allData, function (d) { var pos = getPosition({ data: d }); return [pos[0], pos[1]]; }); var tBounds = this.getPointsBounds(allData, function (d) { var pos = getPosition({ data: d }); return [pos[3], pos[4]]; }); var bounds = [Math.min(sBounds[0], tBounds[0]), Math.min(sBounds[1], tBounds[1]), Math.max(sBounds[2], tBounds[2]), Math.max(sBounds[3], tBounds[3])]; this.updateMeta({ bounds: bounds }); } }, { key: 'renderLayer', value: function renderLayer(_ref3) { var data = _ref3.data, idx = _ref3.idx, objectHovered = _ref3.objectHovered, layerInteraction = _ref3.layerInteraction, mapState = _ref3.mapState, interactionConfig = _ref3.interactionConfig; var brush = interactionConfig.brush; var colorUpdateTriggers = { color: this.config.color, colorField: this.config.colorField, colorRange: this.config.visConfig.colorRange, colorScale: this.config.colorScale, targetColor: this.config.visConfig.targetColor }; var interaction = { // auto highlighting pickable: true, autoHighlight: !brush.enabled, highlightColor: this.config.highlightColor, // brushing brushRadius: brush.config.size * 1000, brushSource: true, brushTarget: true, enableBrushing: brush.enabled }; return [new _arcBrushingLayer2.default((0, _extends3.default)({}, data, interaction, layerInteraction, { id: this.id, idx: idx, fp64: this.config.visConfig['hi-precision'], opacity: this.config.visConfig.opacity, pickedColor: this.config.highlightColor, strokeScale: this.config.visConfig.thickness, // parameters parameters: { depthTest: mapState.dragRotate }, updateTriggers: { getStrokeWidth: { sizeField: this.config.sizeField, sizeRange: this.config.visConfig.sizeRange }, getSourceColor: colorUpdateTriggers, getTargetColor: colorUpdateTriggers } }))]; } }, { key: 'type', get: function get() { return 'arc'; } }, { key: 'isAggregated', get: function get() { return false; } }, { key: 'layerIcon', get: function get() { return _arcLayerIcon2.default; } }, { key: 'requiredLayerColumns', get: function get() { return arcRequiredColumns; } }, { key: 'columnPairs', get: function get() { return this.defaultLinkColumnPairs; } }, { key: 'visualChannels', get: function get() { return (0, _extends3.default)({}, (0, _get3.default)(ArcLayer.prototype.__proto__ || Object.getPrototypeOf(ArcLayer.prototype), 'visualChannels', this), { size: (0, _extends3.default)({}, (0, _get3.default)(ArcLayer.prototype.__proto__ || Object.getPrototypeOf(ArcLayer.prototype), 'visualChannels', this).size, { property: 'stroke' }) }); } }], [{ key: 'findDefaultLayerProps', value: function findDefaultLayerProps(_ref4) { var _ref4$fieldPairs = _ref4.fieldPairs, fieldPairs = _ref4$fieldPairs === undefined ? [] : _ref4$fieldPairs; if (fieldPairs.length < 2) { return []; } var props = { color: (0, _colorUtils.hexToRgb)(_defaultSettings.DEFAULT_LAYER_COLOR.tripArc) }; // connect the first two point layer with arc props.columns = { lat0: fieldPairs[0].pair.lat, lng0: fieldPairs[0].pair.lng, lat1: fieldPairs[1].pair.lat, lng1: fieldPairs[1].pair.lng }; props.label = fieldPairs[0].defaultName + ' -> ' + fieldPairs[1].defaultName + ' arc'; return props; } }]); return ArcLayer; }(_baseLayer2.default); exports.default = ArcLayer; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/layers/arc-layer/arc-layer.js"],"names":["arcPosAccessor","lat0","lng0","lat1","lng1","d","data","fieldIdx","arcPosResolver","arcRequiredColumns","arctVisConfigs","opacity","thickness","colorRange","sizeRange","targetColor","ArcLayer","props","registerVisConfig","getPosition","_","allData","filteredIndex","oldLayerData","opt","config","colorScale","colorDomain","colorField","color","columns","sizeField","sizeScale","sizeDomain","visConfig","cScale","getVisChannelScale","colors","map","hexToRgb","sScale","updateLayerMeta","sameData","reduce","accu","index","pos","every","Number","isFinite","push","sourcePosition","targetPosition","getStrokeWidth","getEncodedChannelValue","getColor","getTargetColor","getSourceColor","sBounds","getPointsBounds","tBounds","bounds","Math","min","max","updateMeta","idx","objectHovered","layerInteraction","mapState","interactionConfig","brush","colorUpdateTriggers","interaction","pickable","autoHighlight","enabled","highlightColor","brushRadius","size","brushSource","brushTarget","enableBrushing","ArcBrushingLayer","id","fp64","pickedColor","strokeScale","parameters","depthTest","dragRotate","updateTriggers","ArcLayerIcon","defaultLinkColumnPairs","property","fieldPairs","length","DEFAULT_LAYER_COLOR","tripArc","pair","lat","lng","label","defaultName","Layer"],"mappings":"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","file":"arc-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 ArcBrushingLayer from 'deckgl-layers/arc-brushing-layer/arc-brushing-layer';\nimport {hexToRgb} from 'utils/color-utils';\nimport ArcLayerIcon from './arc-layer-icon';\nimport {DEFAULT_LAYER_COLOR} from 'constants/default-settings';\n\nexport const arcPosAccessor = ({lat0, lng0, lat1, lng1}) => d => [\n  d.data[lng0.fieldIdx],\n  d.data[lat0.fieldIdx],\n  0,\n  d.data[lng1.fieldIdx],\n  d.data[lat1.fieldIdx],\n  0\n];\n\nexport const arcPosResolver = ({lat0, lng0, lat1, lng1}) =>\n  `${lat0.fieldIdx}-${lng0.fieldIdx}-${lat1.fieldIdx}-${lat1.fieldIdx}}`;\n\nexport const arcRequiredColumns = ['lat0', 'lng0', 'lat1', 'lng1'];\n\nexport const arctVisConfigs = {\n  opacity: 'opacity',\n  thickness: 'thickness',\n  colorRange: 'colorRange',\n  sizeRange: 'strokeWidthRange',\n  targetColor: 'targetColor',\n  'hi-precision': 'hi-precision'\n};\n\nexport default class ArcLayer extends Layer {\n  constructor(props) {\n    super(props);\n    this.registerVisConfig(arctVisConfigs);\n    this.getPosition = memoize(arcPosAccessor, arcPosResolver);\n  }\n\n  get type() {\n    return 'arc';\n  }\n\n  get isAggregated() {\n    return false;\n  }\n\n  get layerIcon() {\n    return ArcLayerIcon;\n  }\n\n  get requiredLayerColumns() {\n    return arcRequiredColumns;\n  }\n\n  get columnPairs() {\n    return this.defaultLinkColumnPairs;\n  }\n\n  get visualChannels() {\n    return {\n      ...super.visualChannels,\n      size: {\n        ...super.visualChannels.size,\n        property: 'stroke'\n      }\n    };\n  }\n\n  static findDefaultLayerProps({fieldPairs = []}) {\n    if (fieldPairs.length < 2) {\n      return [];\n    }\n    const props = {\n      color: hexToRgb(DEFAULT_LAYER_COLOR.tripArc)\n    };\n\n    // connect the first two point layer with arc\n    props.columns = {\n      lat0: fieldPairs[0].pair.lat,\n      lng0: fieldPairs[0].pair.lng,\n      lat1: fieldPairs[1].pair.lat,\n      lng1: fieldPairs[1].pair.lng\n    };\n    props.label = `${fieldPairs[0].defaultName} -> ${\n      fieldPairs[1].defaultName\n    } arc`;\n\n    return props;\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      visConfig: {sizeRange, colorRange, targetColor}\n    } = this.config;\n\n    // arc color\n    const cScale =\n      colorField &&\n      this.getVisChannelScale(\n        colorScale,\n        colorDomain,\n        colorRange.colors.map(hexToRgb)\n      );\n\n    // arc thickness\n    const sScale =\n      sizeField && this.getVisChannelScale(sizeScale, sizeDomain, sizeRange);\n\n    const getPosition = this.getPosition(columns);\n\n    if (!oldLayerData || oldLayerData.getPosition !== getPosition) {\n      this.updateLayerMeta(allData, getPosition);\n    }\n\n    let data;\n    if (\n      oldLayerData &&\n      oldLayerData.data &&\n      opt.sameData &&\n      oldLayerData.getPosition === getPosition\n    ) {\n      data = oldLayerData.data;\n    } else {\n      data = filteredIndex.reduce((accu, index) => {\n        const pos = getPosition({data: allData[index]});\n\n        // if doesn't have point lat or lng, do not add the arc\n        // deck.gl can't handle position == null\n        if (!pos.every(Number.isFinite)) {\n          return accu;\n        }\n\n        accu.push({\n          index,\n          sourcePosition: [pos[0], pos[1], pos[2]],\n          targetPosition: [pos[3], pos[4], pos[5]],\n          data: allData[index]\n        });\n\n        return accu;\n      }, []);\n    }\n\n    const getStrokeWidth = sScale ? d =>\n       this.getEncodedChannelValue(sScale, d.data, sizeField, 0) : 1;\n\n    const getColor = cScale ? d =>\n       this.getEncodedChannelValue(cScale, d.data, colorField) : color;\n\n    const getTargetColor = cScale ? d =>\n       this.getEncodedChannelValue(cScale, d.data, colorField)\n        : targetColor || color;\n\n    return {\n      data,\n      getColor,\n      getSourceColor: getColor,\n      getTargetColor,\n      getStrokeWidth\n    };\n  }\n\n  updateLayerMeta(allData, getPosition) {\n    // get bounds from arcs\n    const sBounds = this.getPointsBounds(allData, d => {\n      const pos = getPosition({data: d});\n      return [pos[0], pos[1]];\n    });\n\n    const tBounds = this.getPointsBounds(allData, d => {\n      const pos = getPosition({data: d});\n      return [pos[3], pos[4]];\n    });\n\n    const bounds = [\n      Math.min(sBounds[0], tBounds[0]),\n      Math.min(sBounds[1], tBounds[1]),\n      Math.max(sBounds[2], tBounds[2]),\n      Math.max(sBounds[3], tBounds[3])\n    ];\n\n    this.updateMeta({bounds});\n  }\n\n  renderLayer({\n    data,\n    idx,\n    objectHovered,\n    layerInteraction,\n    mapState,\n    interactionConfig\n  }) {\n    const {brush} = interactionConfig;\n\n    const colorUpdateTriggers = {\n      color: this.config.color,\n      colorField: this.config.colorField,\n      colorRange: this.config.visConfig.colorRange,\n      colorScale: this.config.colorScale,\n      targetColor: this.config.visConfig.targetColor\n    };\n\n    const interaction = {\n      // auto highlighting\n      pickable: true,\n      autoHighlight: !brush.enabled,\n      highlightColor: this.config.highlightColor,\n\n      // brushing\n      brushRadius: brush.config.size * 1000,\n      brushSource: true,\n      brushTarget: true,\n      enableBrushing: brush.enabled\n    };\n\n    return [\n      new ArcBrushingLayer({\n        ...data,\n        ...interaction,\n        ...layerInteraction,\n        id: this.id,\n        idx,\n        fp64: this.config.visConfig['hi-precision'],\n        opacity: this.config.visConfig.opacity,\n        pickedColor: this.config.highlightColor,\n        strokeScale: this.config.visConfig.thickness,\n\n        // parameters\n        parameters: {depthTest: mapState.dragRotate},\n\n        updateTriggers: {\n          getStrokeWidth: {\n            sizeField: this.config.sizeField,\n            sizeRange: this.config.visConfig.sizeRange\n          },\n          getSourceColor: colorUpdateTriggers,\n          getTargetColor: colorUpdateTriggers\n        }\n      })\n    ];\n  }\n}\n"]}