UNPKG

@antv/s2

Version:

effective spreadsheet render core lib

79 lines 3.28 kB
import EE from '@antv/event-emitter'; import { easeCubicIn as easeFunc } from '@antv/vendor/d3-ease'; import { OriginEventType } from '../../common'; /** 获取执行时间戳 */ const now = () => { var _a; return (_a = performance === null || performance === void 0 ? void 0 : performance.now()) !== null && _a !== void 0 ? _a : Date.now(); }; /** 动画总时间 */ const TOTAL_MS = 800; /** swipe 手势判断阈值 */ const SWIPE_TIME_GAP = 100; /** * 移动端滚动事件 * @see https://github.com/antvis/g-gesture/blob/next/src/event/wheel.ts */ export class WheelEvent extends EE { constructor(canvas) { super(); this.bindPointerDown = (evt) => { window.cancelAnimationFrame(this.raf); this.panning = true; this.preX = evt.x; this.preY = evt.y; this.speedX = 0; this.speedY = 0; this.lastMoveMS = now(); }; this.bindPointerMove = (evt) => { if (this.panning) { const ms = now(); const deltaMS = ms - this.lastMoveMS; const deltaX = this.preX - evt.x; const deltaY = this.preY - evt.y; this.speedX = deltaX / deltaMS; this.speedY = deltaY / deltaMS; this.preX = evt.x; this.preY = evt.y; this.lastMoveMS = ms; this.emit('wheel', Object.assign(Object.assign({}, evt.clone()), { x: evt.x, y: evt.y, deltaX, deltaY })); } }; this.bindPointerUp = (evt) => { this.panning = false; const pointerUpMS = now(); if (!this.speedX || !this.speedY || pointerUpMS - this.lastMoveMS >= SWIPE_TIME_GAP) { return; } const moveLoop = () => { const loopStartMS = now(); this.raf = window.requestAnimationFrame(() => { const ms = now(); const ratio = (ms - pointerUpMS) / TOTAL_MS; if (ratio < 1) { const currentRatio = easeFunc(1 - ratio); const t = ms - loopStartMS; this.emit('wheel', Object.assign(Object.assign({}, evt.clone()), { x: evt.x, y: evt.y, deltaX: this.speedX * currentRatio * t, deltaY: this.speedY * currentRatio * t })); moveLoop(); } }); }; moveLoop(); }; this.canvas = canvas; this.panning = false; this.init(); } init() { this.canvas.addEventListener(OriginEventType.POINTER_DOWN, this.bindPointerDown); this.canvas.addEventListener(OriginEventType.POINTER_MOVE, this.bindPointerMove); this.canvas.addEventListener(OriginEventType.POINTER_UP, this.bindPointerUp); } destroy() { this.canvas.removeEventListener(OriginEventType.POINTER_DOWN, this.bindPointerDown); this.canvas.removeEventListener(OriginEventType.POINTER_MOVE, this.bindPointerMove); this.canvas.removeEventListener(OriginEventType.POINTER_UP, this.bindPointerUp); } } //# sourceMappingURL=wheelEvent.js.map