UNPKG

kepler.gl

Version:

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

269 lines (263 loc) 35.8 kB
"use strict"; 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 _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass")); var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck")); var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn")); var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf")); var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _react = require("react"); var _d3Array = require("d3-array"); var _window = require("global/window"); var _console = _interopRequireDefault(require("global/console")); var _constants = require("@kepler.gl/constants"); 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; })(); } // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var AnimationControllerType = /*#__PURE__*/function (_Component) { function AnimationControllerType() { (0, _classCallCheck2["default"])(this, AnimationControllerType); return _callSuper(this, AnimationControllerType, arguments); } (0, _inherits2["default"])(AnimationControllerType, _Component); return (0, _createClass2["default"])(AnimationControllerType); }(_react.Component); function AnimationControllerFactory() { /** * 4 Animation Window Types * 1. free * |-> |-> * Current time is a fixed range, animate a moving window that calls next animation frames continuously * The increment id based on domain / BASE_SPEED * SPEED * * 2. incremental * | |-> * Same as free, current time is a growing range, only the max value of range increment during animation. * The increment is also based on domain / BASE_SPEED * SPEED * * 3. point * o -> o * Current time is a point, animate a moving point calls next animation frame continuously * The increment is based on domain / BASE_SPEED * SPEED * * 4. interval * o ~> o * Current time is a point. An array of sorted time steps are provided, * animate a moving point jumps to the next step */ var AnimationController = /*#__PURE__*/function (_Component2) { function AnimationController() { var _this; (0, _classCallCheck2["default"])(this, AnimationController); for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } _this = _callSuper(this, AnimationController, [].concat(args)); (0, _defineProperty2["default"])(_this, "state", { isAnimating: false }); (0, _defineProperty2["default"])(_this, "_timer", null); (0, _defineProperty2["default"])(_this, "_startTime", 0); (0, _defineProperty2["default"])(_this, "_animate", function (delay) { _this._startTime = new Date().getTime(); var _loop = function loop() { var current = new Date().getTime(); var delta = current - _this._startTime; if (delta >= delay) { _this._nextFrame(); _this._startTime = new Date().getTime(); } else { _this._timer = (0, _window.requestAnimationFrame)(_loop); } }; _this._timer = (0, _window.requestAnimationFrame)(_loop); }); (0, _defineProperty2["default"])(_this, "_resetAnimationByDomain", function () { var _this$props = _this.props, domain = _this$props.domain, value = _this$props.value, animationWindow = _this$props.animationWindow, updateAnimation = _this$props.updateAnimation; if (!domain) { return; } // interim solution while we fully migrate filter and layer controllers var setTimelineValue = updateAnimation || _this.props.setTimelineValue; if (Array.isArray(value)) { if (animationWindow === _constants.ANIMATION_WINDOW.incremental) { setTimelineValue([value[0], value[0] + 1]); } else { setTimelineValue([domain[0], domain[0] + value[1] - value[0]]); } } else { setTimelineValue(domain[0]); } }); (0, _defineProperty2["default"])(_this, "_resetAnimationByTimeStep", function () { var _this$props2 = _this.props, _this$props2$steps = _this$props2.steps, steps = _this$props2$steps === void 0 ? null : _this$props2$steps, updateAnimation = _this$props2.updateAnimation; if (!steps) return; // interim solution while we fully migrate filter and layer controllers var setTimelineValue = updateAnimation || _this.props.setTimelineValue; // go to the first steps setTimelineValue([steps[0], 0]); }); (0, _defineProperty2["default"])(_this, "_resetAnimation", function () { if (_this.props.animationWindow === _constants.ANIMATION_WINDOW.interval) { _this._resetAnimationByTimeStep(); } else { _this._resetAnimationByDomain(); } }); (0, _defineProperty2["default"])(_this, "_startAnimation", function () { var _this$props$speed = _this.props.speed, speed = _this$props$speed === void 0 ? 1 : _this$props$speed; _this._clearTimer(); if (speed > 0) { if (_this.props.animationWindow === _constants.ANIMATION_WINDOW.interval) { // animate by interval // 30*600 var steps = _this.props.steps; if (!Array.isArray(steps) || !steps.length) { _console["default"].warn('animation steps should be an array'); return; } // when speed = 1, animation should loop through 600 frames at 60 FPS // calculate delay based on # steps var delay = _constants.BASE_SPEED * (1000 / _constants.FPS) / steps.length / (speed || 1); _this._animate(delay); } else { _this._timer = (0, _window.requestAnimationFrame)(_this._nextFrame); } } _this.setState({ isAnimating: true }); }); (0, _defineProperty2["default"])(_this, "_clearTimer", function () { if (_this._timer) { (0, _window.cancelAnimationFrame)(_this._timer); _this._timer = null; } }); (0, _defineProperty2["default"])(_this, "_pauseAnimation", function () { _this._clearTimer(); _this.setState({ isAnimating: false }); }); (0, _defineProperty2["default"])(_this, "_nextFrame", function () { _this._timer = null; var nextValue = _this.props.animationWindow === _constants.ANIMATION_WINDOW.interval ? _this._nextFrameByTimeStep() : _this._nextFrameByDomain(); // interim solution while we fully migrate filter and layer controllers var setTimelineValue = _this.props.updateAnimation || _this.props.setTimelineValue; setTimelineValue(nextValue); }); return _this; } (0, _inherits2["default"])(AnimationController, _Component2); return (0, _createClass2["default"])(AnimationController, [{ key: "componentDidMount", value: function componentDidMount() { this._startOrPauseAnimation(); } }, { key: "componentDidUpdate", value: function componentDidUpdate() { this._startOrPauseAnimation(); } }, { key: "componentWillUnmount", value: function componentWillUnmount() { if (this._timer) { (0, _window.cancelAnimationFrame)(this._timer); } } }, { key: "_startOrPauseAnimation", value: function _startOrPauseAnimation() { var _this$props3 = this.props, isAnimating = _this$props3.isAnimating, _this$props3$speed = _this$props3.speed, speed = _this$props3$speed === void 0 ? 1 : _this$props3$speed; if (!this._timer && isAnimating && speed > 0) { this._startAnimation(); } else if (this._timer && !isAnimating) { this._pauseAnimation(); } } }, { key: "_nextFrameByDomain", value: function _nextFrameByDomain() { var _this$props4 = this.props, domain = _this$props4.domain, value = _this$props4.value, _this$props4$speed = _this$props4.speed, speed = _this$props4$speed === void 0 ? 1 : _this$props4$speed, _this$props4$baseSpee = _this$props4.baseSpeed, baseSpeed = _this$props4$baseSpee === void 0 ? 600 : _this$props4$baseSpee, animationWindow = _this$props4.animationWindow; if (!domain) { return; } var delta = (domain[1] - domain[0]) / baseSpeed * speed; // loop when reaches the end // current time is a range if (Array.isArray(value)) { var value0; var value1; if (animationWindow === _constants.ANIMATION_WINDOW.incremental) { var lastFrame = value[1] + delta > domain[1]; value0 = value[0]; value1 = lastFrame ? value[0] + 1 : value[1] + delta; } else { // use value[0] to display the last item duration as the first item var _lastFrame = value[0] + delta > domain[1]; value0 = _lastFrame ? domain[0] : value[0] + delta; value1 = value0 + value[1] - value[0]; } return [value0, value1]; } // current time is a point return Number(value) + delta > domain[1] ? domain[0] : Number(value) + delta; } }, { key: "_nextFrameByTimeStep", value: function _nextFrameByTimeStep() { var _this$props5 = this.props, _this$props5$steps = _this$props5.steps, steps = _this$props5$steps === void 0 ? null : _this$props5$steps, value = _this$props5.value; if (!steps) return; var val = Array.isArray(value) ? value[0] : Number(value); var index = (0, _d3Array.bisectLeft)(steps, val); var nextIdx = index >= steps.length - 1 ? 0 : index + 1; // why do we need to pass an array of two objects? are we reading nextIdx at some point? // _nextFrameByDomain only returns one value return [steps[nextIdx], nextIdx]; } }, { key: "render", value: function render() { var isAnimating = this.state.isAnimating; var children = this.props.children; return typeof children === 'function' ? children(isAnimating, this._startAnimation, this._pauseAnimation, this._resetAnimation, this.props.timeline, this.props.setTimelineValue) : null; } }]); }(_react.Component); (0, _defineProperty2["default"])(AnimationController, "defaultProps", { baseSpeed: _constants.BASE_SPEED, speed: 1, steps: null, animationWindow: _constants.ANIMATION_WINDOW.free }); return AnimationController; } var _default = exports["default"] = AnimationControllerFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","require","_d3Array","_window","_console","_interopRequireDefault","_constants","_callSuper","t","o","e","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","call","AnimationControllerType","_Component","_classCallCheck2","arguments","_inherits2","_createClass2","Component","AnimationControllerFactory","AnimationController","_Component2","_this","_len","length","args","Array","_key","concat","_defineProperty2","isAnimating","delay","_startTime","Date","getTime","loop","current","delta","_nextFrame","_timer","requestAnimationFrame","_this$props","props","domain","value","animationWindow","updateAnimation","setTimelineValue","isArray","ANIMATION_WINDOW","incremental","_this$props2","_this$props2$steps","steps","interval","_resetAnimationByTimeStep","_resetAnimationByDomain","_this$props$speed","speed","_clearTimer","Console","warn","BASE_SPEED","FPS","_animate","setState","cancelAnimationFrame","nextValue","_nextFrameByTimeStep","_nextFrameByDomain","key","componentDidMount","_startOrPauseAnimation","componentDidUpdate","componentWillUnmount","_this$props3","_this$props3$speed","_startAnimation","_pauseAnimation","_this$props4","_this$props4$speed","_this$props4$baseSpee","baseSpeed","value0","value1","lastFrame","Number","_this$props5","_this$props5$steps","val","index","bisectLeft","nextIdx","render","state","children","_resetAnimation","timeline","free","_default","exports"],"sources":["../../../src/common/animation-control/animation-controller.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Component} from 'react';\nimport {bisectLeft} from 'd3-array';\nimport {requestAnimationFrame, cancelAnimationFrame} from 'global/window';\nimport Console from 'global/console';\nimport {BASE_SPEED, FPS, ANIMATION_WINDOW} from '@kepler.gl/constants';\nimport {Timeline} from '@kepler.gl/types';\n\ninterface AnimationControllerProps<T extends number | number[]> {\n  isAnimating?: boolean;\n  speed?: number;\n  updateAnimation?: (x: T) => void;\n  setTimelineValue: (x: T) => void;\n  timeline?: Timeline;\n  animationWindow?: string;\n  steps?: number[] | null;\n  domain: number[] | null;\n  value: T;\n  baseSpeed?: number;\n  children?: (\n    isAnimating: boolean | undefined,\n    startAnimation: () => void,\n    pauseAnimation: () => void,\n    resetAnimation: () => void,\n    timeline: Timeline | undefined,\n    setTimelineValue: (x: T) => void\n  ) => React.ReactElement | null;\n}\n\nclass AnimationControllerType<T extends number | number[]> extends Component<\n  AnimationControllerProps<T>\n> {}\n\nfunction AnimationControllerFactory(): typeof AnimationControllerType {\n  /**\n   * 4 Animation Window Types\n   * 1. free\n   *  |->  |->\n   * Current time is a fixed range, animate a moving window that calls next animation frames continuously\n   * The increment id based on domain / BASE_SPEED * SPEED\n   *\n   * 2. incremental\n   * |    |->\n   * Same as free, current time is a growing range, only the max value of range increment during animation.\n   * The increment is also based on domain / BASE_SPEED * SPEED\n   *\n   * 3. point\n   * o -> o\n   * Current time is a point, animate a moving point calls next animation frame continuously\n   * The increment is based on domain / BASE_SPEED * SPEED\n   *\n   * 4. interval\n   * o ~> o\n   * Current time is a point. An array of sorted time steps are provided,\n   * animate a moving point jumps to the next step\n   */\n  class AnimationController<T extends number | number[]> extends Component<\n    AnimationControllerProps<T>\n  > {\n    static defaultProps = {\n      baseSpeed: BASE_SPEED,\n      speed: 1,\n      steps: null,\n      animationWindow: ANIMATION_WINDOW.free\n    };\n\n    state = {\n      isAnimating: false\n    };\n\n    componentDidMount() {\n      this._startOrPauseAnimation();\n    }\n\n    componentDidUpdate() {\n      this._startOrPauseAnimation();\n    }\n\n    componentWillUnmount() {\n      if (this._timer) {\n        cancelAnimationFrame(this._timer);\n      }\n    }\n\n    _timer = null;\n    _startTime = 0;\n\n    _startOrPauseAnimation() {\n      const {isAnimating, speed = 1} = this.props;\n      if (!this._timer && isAnimating && speed > 0) {\n        this._startAnimation();\n      } else if (this._timer && !isAnimating) {\n        this._pauseAnimation();\n      }\n    }\n\n    _animate = delay => {\n      this._startTime = new Date().getTime();\n\n      const loop = () => {\n        const current = new Date().getTime();\n        const delta = current - this._startTime;\n\n        if (delta >= delay) {\n          this._nextFrame();\n          this._startTime = new Date().getTime();\n        } else {\n          this._timer = requestAnimationFrame(loop);\n        }\n      };\n\n      this._timer = requestAnimationFrame(loop);\n    };\n\n    _resetAnimationByDomain = () => {\n      const {domain, value, animationWindow, updateAnimation} = this.props;\n      if (!domain) {\n        return;\n      }\n      // interim solution while we fully migrate filter and layer controllers\n      const setTimelineValue = updateAnimation || this.props.setTimelineValue;\n\n      if (Array.isArray(value)) {\n        if (animationWindow === ANIMATION_WINDOW.incremental) {\n          setTimelineValue([value[0], value[0] + 1] as T);\n        } else {\n          setTimelineValue([domain[0], domain[0] + value[1] - value[0]] as T);\n        }\n      } else {\n        setTimelineValue(domain[0] as T);\n      }\n    };\n\n    _resetAnimationByTimeStep = () => {\n      const {steps = null, updateAnimation} = this.props;\n      if (!steps) return;\n      // interim solution while we fully migrate filter and layer controllers\n      const setTimelineValue = updateAnimation || this.props.setTimelineValue;\n\n      // go to the first steps\n      setTimelineValue([steps[0], 0] as T);\n    };\n\n    _resetAnimation = () => {\n      if (this.props.animationWindow === ANIMATION_WINDOW.interval) {\n        this._resetAnimationByTimeStep();\n      } else {\n        this._resetAnimationByDomain();\n      }\n    };\n\n    _startAnimation = () => {\n      const {speed = 1} = this.props;\n      this._clearTimer();\n      if (speed > 0) {\n        if (this.props.animationWindow === ANIMATION_WINDOW.interval) {\n          // animate by interval\n          // 30*600\n          const {steps} = this.props;\n          if (!Array.isArray(steps) || !steps.length) {\n            Console.warn('animation steps should be an array');\n            return;\n          }\n          // when speed = 1, animation should loop through 600 frames at 60 FPS\n          // calculate delay based on # steps\n          const delay = (BASE_SPEED * (1000 / FPS)) / steps.length / (speed || 1);\n          this._animate(delay);\n        } else {\n          this._timer = requestAnimationFrame(this._nextFrame);\n        }\n      }\n      this.setState({isAnimating: true});\n    };\n\n    _clearTimer = () => {\n      if (this._timer) {\n        cancelAnimationFrame(this._timer);\n        this._timer = null;\n      }\n    };\n\n    _pauseAnimation = () => {\n      this._clearTimer();\n      this.setState({isAnimating: false});\n    };\n\n    _nextFrame = () => {\n      this._timer = null;\n      const nextValue =\n        this.props.animationWindow === ANIMATION_WINDOW.interval\n          ? this._nextFrameByTimeStep()\n          : this._nextFrameByDomain();\n\n      // interim solution while we fully migrate filter and layer controllers\n      const setTimelineValue = this.props.updateAnimation || this.props.setTimelineValue;\n      setTimelineValue(nextValue as T);\n    };\n\n    _nextFrameByDomain() {\n      const {domain, value, speed = 1, baseSpeed = 600, animationWindow} = this.props;\n      if (!domain) {\n        return;\n      }\n      const delta = ((domain[1] - domain[0]) / baseSpeed) * speed;\n\n      // loop when reaches the end\n      // current time is a range\n      if (Array.isArray(value)) {\n        let value0: number;\n        let value1: number;\n        if (animationWindow === ANIMATION_WINDOW.incremental) {\n          const lastFrame = value[1] + delta > domain[1];\n          value0 = value[0];\n          value1 = lastFrame ? value[0] + 1 : value[1] + delta;\n        } else {\n          // use value[0] to display the last item  duration as the first item\n          const lastFrame = value[0] + delta > domain[1];\n          value0 = lastFrame ? domain[0] : value[0] + delta;\n          value1 = value0 + value[1] - value[0];\n        }\n        return [value0, value1];\n      }\n\n      // current time is a point\n      return Number(value) + delta > domain[1] ? domain[0] : Number(value) + delta;\n    }\n\n    _nextFrameByTimeStep() {\n      const {steps = null, value} = this.props;\n      if (!steps) return;\n      const val = Array.isArray(value) ? value[0] : Number(value);\n      const index = bisectLeft(steps, val);\n      const nextIdx = index >= steps.length - 1 ? 0 : index + 1;\n\n      // why do we need to pass an array of two objects? are we reading nextIdx at some point?\n      // _nextFrameByDomain only returns one value\n      return [steps[nextIdx], nextIdx];\n    }\n\n    render() {\n      const {isAnimating} = this.state;\n      const {children} = this.props;\n\n      return typeof children === 'function'\n        ? children(\n            isAnimating,\n            this._startAnimation,\n            this._pauseAnimation,\n            this._resetAnimation,\n            this.props.timeline,\n            this.props.setTimelineValue\n          )\n        : null;\n    }\n  }\n\n  return AnimationController;\n}\n\nexport default AnimationControllerFactory;\n"],"mappings":"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","ignoreList":[]}