FlyingControls

Flying controls allow the camera to move around like an airplane.

Constructor

FlyingControls(object : Camera, domElement : HTMLElement)

object
The camera to be controlled (required).
domElement
The HTML element used for event listeners (optional). By default this is the whole document, however if you only want to the controls to work over a specific element (e.g. the canvas) you can specify that here.

Properties

.domElement : HTMLElement

The HTMLElement used to listen for mouse / touch events. This must be passed in the constructor; changing it here will not set up new event listeners. Default is the whole document.

.enabled : Boolean

Whether or not the controls are enabled.

.enableDamping : Boolean

Whether to enable damping (inertia), which is used to give a sense of weight to the controls. Default is true.

Note that if this is enabled, you must call .update() in your animation loop.

.enableKeys : Boolean

Enable or disable the use of keyboard controls. Default is true.

.enablePan : Boolean

Enable or disable camera panning. Default is true.

.enableRotate : Boolean

Enable or disable horizontal and vertical rotation of the camera. Default is true.

Note that it is possible to disable a single axis by setting the min and max of the polar angle or azimuth angle to the same value, which will cause the vertical or horizontal rotation to be fixed at that value.

.enableTurnover : Boolean

Enable or disable moving the camera over the head. Default is false.

.enableZoom : Boolean

Enable or disable zooming (dollying) of the camera.

.inTween : Boolean

Flag which says whether the camera is currently in the state of tweening.

.maxAzimuthAngle : Float

How far you can orbit horizontally, upper limit. Range is -Math.PI to Math.PI (or Infinity for no limit) and default is Infinity;

.maxDistance : Float

How far you can dolly out (PerspectiveCamera only). Default is Infinity.

.maxPolarAngle : Float

How far you can orbit vertically, upper limit. Range is 0 to Math.PI radians, and default is Math.PI.

.maxZoom : Float

How far you can zoom out (OrthographicCamera only). Default is Infinity.

.minAzimuthAngle : Float

How far you can orbit horizontally, lower limit. Range is -Math.PI to Math.PI (or -Infinity for no limit) and default is -Infinity;

.minDistance : Float

How far you can dolly in (PerspectiveCamera only). Default is 0.

.minPolarAngle : Float

How far you can orbit vertically, lower limit. Range is 0 to Math.PI radians, and default is 0.

.minZoom : Float

How far you can zoom in (OrthographicCamera only). Default is 0.

.mouseButtons : Object

This object contains references to the mouse buttons used for the controls.

controls.mouseButtons = { ROTATE: v3d.MOUSE.LEFT, ZOOM: v3d.MOUSE.MIDDLE, PAN: v3d.MOUSE.RIGHT }

.object : Camera

The camera (or other object) that is being controlled.

.panInertia : Float

The panning damping inertia used if .enableDamping is set to true. Note that for this to work, you must call .update() in your animation loop. Default is 0.05.

.panSpeed : Float

Speed of panning. Default is 20.0.

.panSpeedKey : Float

Speed of panning (pixels moved) when using keyboard arrow keys. Default is 0.15.

.panSpeedTouch : Float

Speed of panning (pixels moved) when using touch-based controls. Default is 15.0.

.rotateInertia : Float

The rotation damping inertia used if .enableDamping is set to true. Note that for this to work, you must call .update() in your animation loop. Default is 0.05.

.rotateInertiaTouch : Float

Same as .rotateInertia, but for the touch-based controls used on mobile devices. Default value is 0.05.

.rotateSpeed : Float

Speed of rotation. Default is 0.9.

.rotateSpeedTouch : Float

Speed of rotation on touch-based devices. Default is 0.75.

.zoomSpeed : Float

Speed of zooming / dollying. Default is 150.0.

.zoomSpeedKey : Float

Speed of zooming when using keyboard arrow keys. Default is 0.5.

.zoomSpeedTouch : Float

Speed of rotation on touch-based devices. Default is 20.0.

.zoomInertia : Float

The zoom damping inertia used if .enableDamping is set to true. Note that for this to work, you must call .update() in your animation loop. Default is 0.05.

.zoomInertiaTouch : Float

Same as .zoomInertia, but for the touch-based controls used on mobile devices. Default is 0.05.

Methods

.dispose()

Remove all the event listeners.

.tween(toPosition : Vector3, toTarget : Vector3, time : Float, finishCb : Function, movementType : Constant)

toPosition
The new position of the camera.
toTarget
The new target point.
time
The length of the tween animation.
finishCb
A callback to be called after the tween animation ends.
movementType
The movement interpolation. Can be v3d.TweenLinear (default) or v3d.TweenSpherical.

Change the camera's current position and target point to the specified new position and target smoothly over the specified time.

.tweenZoomTo(toTarget : Vector3, toZoom : Float, time : Float, finishCb : Function)

toTarget
The new target point.
toZoom
The new zoom factor.
time
The length of the tween animation.
finishCb
A callback to be called after the tween animation ends.

Change the orthographic camera target point and zoom factor smoothly over the specified period of time.

.update() → Boolean

Update the controls. Must be called after any manual changes to the camera's transform, or in the update loop if .autoRotate or .enableDamping are set.

Source

For more info on how to obtain the source code of this module see this page.