From 53390c916f2c40263ce1bfb6f98cddb6bfce8195 Mon Sep 17 00:00:00 2001 From: Xiaoji Chen Date: Mon, 11 Jan 2021 11:09:11 -0800 Subject: [PATCH] Smooth zoom on scroll (#1288) --- src/utils/map-controller.js | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/src/utils/map-controller.js b/src/utils/map-controller.js index d157f184d..88457da76 100644 --- a/src/utils/map-controller.js +++ b/src/utils/map-controller.js @@ -21,7 +21,6 @@ import MapState from './map-state'; import {LinearInterpolator} from './transition'; import TransitionManager, {TRANSITION_EVENTS} from './transition-manager'; -import debounce from './debounce'; const NO_TRANSITION_PROPS = { transitionDuration: 0 @@ -68,7 +67,6 @@ export default class MapController { constructor() { this.handleEvent = this.handleEvent.bind(this); - this._onWheelEnd = debounce(this._onWheelEnd, 100); } /** @@ -315,16 +313,16 @@ export default class MapController { } const newMapState = this.mapState.zoom({pos, scale}); - this.updateViewport(newMapState, NO_TRANSITION_PROPS, {isZooming: true}); - // Wheel events are discrete, let's wait a little before resetting isZooming - this._onWheelEnd(); + this.updateViewport( + newMapState, + Object.assign({}, LINEAR_TRANSITION_PROPS, { + transitionInterpolator: new LinearInterpolator({around: pos}) + }), + {isZooming: true} + ); return true; } - _onWheelEnd() { - this.setState({isZooming: false}); - } - // Default handler for the `pinchstart` event. _onPinchStart(event) { const pos = this.getCenter(event);