The base class for all viewport controllers.
A controller class can be passed to either the Deck
class's controller prop or a View
class's controller prop to specify viewport interactivity.
The base Controller class supports the following options:
scrollZoom
(Boolean|Object) - enable zooming with mouse wheel. Defaulttrue
. If an object is supplied, it may contain the following fields to customize the zooming behavior:speed
(Number) - scaler that translates wheel delta to the change of viewport scale. Default0.01
.smooth
(Boolean) - smoothly transition to the new zoom. If enabled, will provide a slightly lagged but smoother experience. Defaultfalse
.
dragPan
(Boolean) - enable panning with pointer drag. Defaulttrue
dragRotate
(Boolean) - enable rotating with pointer drag. Defaulttrue
doubleClickZoom
(Boolean) - enable zooming with double click. Defaulttrue
touchZoom
(Boolean) - enable zooming with multi-touch. Defaulttrue
touchRotate
(Boolean) - enable rotating with multi-touch. Use two-finger rotating gesture for horizontal and three-finger swiping gesture for vertical rotation. Defaultfalse
keyboard
(Boolean|Object) - enable interaction with keyboard. Defaulttrue
. If an object is supplied, it may contain the following fields to customize the keyboard behavior:zoomSpeed
(Number) - speed of zoom using +/- keys. Default2
.moveSpeed
(Number) - speed of movement using arrow keys, in pixels.rotateSpeedX
(Number) - speed of rotation using shift + left/right arrow keys, in degrees. Default15
.rotateSpeedY
(Number) - speed of rotation using shift + up/down arrow keys, in degrees. Default10
.
dragMode
(String) - drag behavior without pressing function keys, one ofpan
androtate
.inertia
(Boolean|Number) - Enable inertia after panning/pinching. If a number is provided, indicates the duration of time over which the velocity reduces to zero, in milliseconds. Defaultfalse
.
A controller is not meant to be instantiated by the application. The following methods are documented for creating custom controllers that extend the base Controller class.
import {Controller} from 'deck.gl';
class MyController extends Controller {
constructor(options = {}) {
super(MyViewState, options);
}
}
The constructor takes two arguments:
ViewState
- a class that implements the following methods:getViewportProps()
- returns an object that describes the view stategetInteractiveState()
- returns an object that contains the internal state of the ongoing interactionshortestPathFrom(viewState)
- returns an object that describes another view state that is closest to this view state. This is used by viewport transition when there are multiple equivalent ways to define a view state (e.g.bearing: 240
andbearing: -120
)- methods that return a new ViewState with updated props:
panStart
pan
panEnd
rotateStart
rotate
rotateEnd
zoomStart
zoom
zoomEnd
zoomIn
zoomOut
moveLeft
moveRight
moveUp
moveDown
rotateLeft
rotateRight
rotateUp
rotateDown
options
(Object) - options and view state props
Called by the event manager to handle pointer events. This method delegate to the following methods to handle the default events:
_onPanStart(event)
_onPan(event)
_onPanEnd(event)
_onPinchStart(event)
_onPinch(event)
_onPinchEnd(event)
_onTriplePanStart(event)
_onTriplePan(event)
_onTriplePanEnd(event)
_onDoubleTap(event)
_onWheel(event)
_onKeyDown(event)
See Event object documentation.
Called by the view when the view state updates. This method handles adding/removing event listeners based on user options.
Called by the event handlers, this method updates internal state, and invokes onViewStateChange
callback with a new map state.
Utility used by the event handlers, returns pointer position [x, y]
from any event.
Utility used by the event handlers, returns true
if ctrl/alt/meta key is pressed during any event.
Utility used by the event handlers, returns true
if a pointer position [x, y]
is inside the current view.
If event
is provided, returns false
if the event is already handled, and mark the event as handled if the point is in bounds. This can be used to make sure that certain events are only handled by one controller, when there are overlapping viewports.
Returns true
if the user is dragging the view.
import {Controller} from 'deck.gl';
class MyController extends Controller{
constructor(options = {}) {
super(MyViewState, options);
this.events = ['pointermove'];
}
handleEvent(event) {
if (event.type === 'pointermove') {
// do something
} else {
super.handleEvent(event);
}
}
}
In its constructor, a controller class can optionally specify a list of event names that it subscribes to with the events
field. A full list of supported events can be found here.
Note that the following events are always toggled on/off by user options:
scrollZoom
-['wheel']
dragPan
anddragRotate
-['pan']
touchZoom
-['pinch']
touchRotate
-['pinch', 'tripan]
doubleClickZoom
-['doubletap']
keyboard
-['keydown']