For detailed explanations and code examples about deck.gl's views system, visit the Views and Projections article.
The View
class and its subclasses are used to specify where and how your deck.gl layers should be rendered. Applications typically instantiate at least one View
subclass.
Views allow you to specify:
- A unique
id
. - The position and extent of the view on the canvas:
x
,y
,width
, andheight
. - Certain camera parameters specifying how your data should be projected into this view, e.g. field of view, near/far planes, perspective vs. orthographic, etc.
- The controller to be used for this view. A controller listens to pointer events and touch gestures, and translates user input into changes in the view state. If enabled, the camera becomes interactive.
deck.gl offers a set of View
classes that package the camera and controller logic that you need to visualize and interact with your data. You may choose one or multiple View
classes based on the type of data (e.g. geospatial, 2D chart) and the desired perspective (top down, first-person, etc).
const view = new View({id, x, y, width, height, ...});
Parameters:
A unique id of the view. In a multi-view use case, this is important for matching view states and place contents into this view.
A relative (e.g. '50%'
) or absolute position. Default 0
.
A relative (e.g. '50%'
) or absolute position. Default 0
.
A relative (e.g. '50%'
) or absolute extent. Default '100%'
.
A relative (e.g. '50%'
) or absolute extent. Default '100%'
.
Options for viewport interactivity.
null
orfalse
: this view is not interactive.true
: initiates the default controller with default options.Controller
class (not instance): initiates the provided controller with default options.Object
: controller options. This will be merged with the default controller options.controller.type
: the controller class- For other options, consult the documentation of Controller.
Default null
.
The optional viewState
property enables a View
to specify, select or select-and-modify its view state.
viewState
is an overloaded property that can take either just a view state id string, or an object specifying view state parameters and optionally a view state id string:
null
(default): Will select a view state based onview.id
, falling back to using the first view state.String
: Will attempt to match the indicated view state.Object
(withid
field): if the object contains anid
field which matches a dynamic view state, the remaining fields inView.viewState
will extend (be merged into a copy of) the selected dynamic view state.Object
(with noid
field): If noid
is provided, theView.viewState
object will be used directly as the view state, essentially representing a fixed or constant view state.
Note that specifying viewState
as an object with an id
field effectively allows the View to modify a dynamic view state by overriding some of its fields. This is useful in multiview situations where it enables having one view that fixes some parameters (eg. zoom, pitch and bearing to show an overview map).
The viewState
property is intended to support a number of use cases:
- Sharing view states between multiple views - If a
View
id is different from the designed view state's id. - specify a complete, constant (fixed) view state directly in the view
- Overriding a partial set of view state properties from a selected view state.
Clears the contents (pixels) of the viewport. The value of the clear
prop is passed as an argument to luma.gl's clear
function. If true
clears color and depth buffers. If an object, behaviour is controlled by the following fields:
color
(Boolean or Array) - if notfalse
, clears all active color buffers with either the provided color or the currently set clear color.depth
(Boolean) - iftrue
, clears the depth buffer.stencil
(Boolean) - iftrue
clears the stencil buffer.
Note that deck.gl always clears the screen before each render, and clearing, while cheap, is not totally free. This means that viewports should only specify the clear
property if they need additional clearing, e.g. because they are rendering on top of another viewport, or want to have a different background color etc.
Default false
.
Projection matrix.
If projectionMatrix
is not supplied, the View
class will build a projection matrix from the following parameters:
Field of view covered by camera, in the perspective case. In degrees. Default 75
.
Aspect ratio. Defaults to the Viewport's width/height
ratio.
Distance of near clipping plane. Default 0.1
.
Distance of far clipping plane. Default 1000
.
Whether to create an orthographic or perspective projection matrix. Default is false
(perspective projection).
Modifier of viewport scale. Corresponds to the number of pixels per meter. Default 1
.
Note: most applications just create Views with the appropriate props and do not need to call the following View methods directly.
Returns true
if deck.gl can determine that the supplied View
instance is identical (equivalent) with this view.
view.equals(otherView)
otherView
(View
) - Another view instance to compare with.
Returns:
true
- the given view is identical to the current one.
Note: For speed, deck.gl uses shallow equality. This means that a value of false
does not guarantee that the views are not equivalent.
view.makeViewport({width, height, viewState})
Parameters:
width
(Number
) - Dimension in pixels of the target viewport.height
(Number
) - Dimension in pixels of the target viewport.viewState
(Object
) - view state compatible with the currentView
subclass in use. Note that any prop provided to theView
constructor will override that inside theviewState
.
Returns a Viewport using the viewport type, props in the View
and provided dimensions and view state.
Returns the actual pixel position and size that this View
will occupy in a given "canvas" size.
const {x, y, width, height} = view.getDimensions({width, height});
Parameters:
width
(Number
) - Dimension in CSS pixels of the deck.gl "canvas".height
(Number
) - Dimension in CSS pixels of the deck.gl "canvas".
Returns an object containing the following fields:
x
(Number
) - x position in CSS pixelsy
(Number
) - y position in CSS pixelswidth
(Number
) - width in CSS pixelsheight
(Number
) - height in CSS pixels
- The
View
class and its subclasses are perhaps best thought of as geospatially enabled counterparts of the typicalCamera
classes found in most 3D libraries.