3. Camera Control¶
Vuer provides two types of cameras for viewing your 3D scenes.
Main Camera - The default user viewport with interactive OrbitControls
Virtual Cameras (CameraView) - Programmable cameras for off-screen rendering and multi-view displays
This chapter only covers the usage of the first type of camera. You’ll learn how to:
Camera Behavior in VR/AR
How to disable default camera interaction controls
Set up different camera types (Perspective and Orthographic)
Configure camera parameters like field of view and position
By default, Vuer provides a perspective camera at [0, 2, 2] with OrbitControls enabled, so you can start building scenes immediately. This chapter shows you how to customize these defaults.
VR/AR Camera Behavior¶
Key parameters: left, right, top, bottom (define view boundaries), near, far, position, lookAt, makeDefault
In WebXR sessions (VR/AR), the camera is controlled by the headset. Simply create a normal scene - Vuer automatically handles VR/AR mode when the user clicks the VR button
VR Camera Characteristics:
Position: Tracked by headset (6DOF)
Rotation: Tracked by headset
IPD (interpupillary distance): Automatically handled
Render: Stereo rendering for both eyes
OrbitControls: Automatically disabled in VR mode
Note: To test VR mode, you need a VR headset and a WebXR-compatible browser. The VR button appears automatically in the top-right corner of the scene.
Interactive Camera Controls¶
Vuer provides interactive camera controls through the OrbitControls component. By default, Vuer includes OrbitControls in every scene, so you can immediately interact with your 3D scenes.
Mouse/Touch Controls:
Left click + drag: Rotate around target
Right click + drag: Pan (move sideways)
Scroll wheel: Zoom in/out
Touch: One finger to rotate, two fingers to pan/zoom
Basic Scene Setup¶
Here’s a minimal scene with default controls:
from vuer import Vuer, VuerSession
from vuer.schemas import Scene, Box
app = Vuer()
@app.spawn(start=True)
async def main(session: VuerSession):
session.set @ Scene(
Box(args=[1, 1, 1], position=[0, 0.5, 0], key="box"),
# Default camera at [0, 2, 2] with OrbitControls enabled
)
await session.forever()
The scene above automatically includes:
A
PerspectiveCameraat position[0, 2, 2]OrbitControlsfor interactionDefault lighting
Fixed Camera (No Controls)¶
To create a fixed camera view without interaction, use a custom bgChildren without SceneCameraControl:
from vuer import Vuer, VuerSession
from vuer.schemas import Scene, Box, Grid, HemisphereLightStage, SceneCamera
app = Vuer()
@app.spawn(start=True)
async def main(session: VuerSession):
session.set @ Scene(
Box(args=[1, 1, 1], position=[0, 0.5, 0], key="box"),
bgChildren=[
Grid(key="grid"),
HemisphereLightStage(key="light-stage"),
SceneCamera(key="SceneCamera", position=[0, 5, 10]),
# Note: No SceneCameraControl = no mouse interaction
],
)
await session.forever()
This keeps Grid and lighting while removing camera controls.
Use cases:
Cinematic presentations or product showcases
Fixed viewpoint demonstrations
Guided tours with programmatic camera animation
Streaming Camera Updates to the Server¶
You can stream camera position and orientation changes to the server in real-time by enabling the stream parameter:
from vuer import Vuer, VuerSession
from vuer.schemas import Scene, Box, OrbitControls
app = Vuer()
@app.spawn(start=True)
async def main(session: VuerSession):
session.set @ Scene(
Box(args=[1, 1, 1], position=[0, 0.5, 0], key="box"),
bgChildren=[
OrbitControls(stream=True, key="controls"),
],
)
# Listen for camera move events
@session.on("CAMERA_MOVE")
async def handle_camera_move(event):
camera = event.value["camera"]
print(f"Camera position: {camera.position}")
# Use camera data for custom logic (recording, analysis, etc.)
await session.forever()
Use cases:
Record camera trajectories for animation playback
Send camera state to other clients for shared viewing
Analyze camera movement patterns
Synchronize multiple views with camera position
Camera Types¶
Vuer supports two main camera types: PerspectiveCamera and OrthographicCamera. Each serves different purposes in 3D visualization.
PerspectiveCamera - Realistic View¶
Perspective cameras mimic how the human eye sees the world: objects appear smaller as they get farther away. This is the default camera type and is ideal for most 3D applications.
from vuer import Vuer, VuerSession
from vuer.schemas import Scene, Box
from vuer.schemas import PerspectiveCamera, OrbitControls
app = Vuer()
@app.spawn(start=True)
async def main(session: VuerSession):
session.set @ Scene(
Box(args=[1, 1, 1], position=[0, 0.5, 0], key="box"),
Box(args=[1, 1, 1], position=[0, 0.5, -5], key="far-box"),
up=[0, 1, 0],
grid=True,
rawChildren=[
PerspectiveCamera(
key="main-camera",
fov=60, # Field of view in degrees
near=0.1, # Near clipping plane
far=1000, # Far clipping plane
position=[0, 3, 5],
lookAt=[0, 0, 0], # Point at scene center
makeDefault=True,
),
],
)
await session.forever()
Key parameters: fov (field of view, default: 75°), near (default: 0.1), far (default: 1000), position, lookAt, makeDefault
When to use:
Games and interactive 3D applications
Product visualization and showcases
Architectural walkthroughs
Any scene requiring depth perception
OrthographicCamera - Technical View¶
Orthographic cameras render objects at the same size regardless of distance. Parallel lines remain parallel, making it perfect for technical drawings and 2D games.
from vuer import Vuer, VuerSession
from vuer.schemas import Scene, Box
from vuer.schemas import OrthographicCamera, OrbitControls
app = Vuer()
@app.spawn(start=True)
async def main(session: VuerSession):
session.set @ Scene(
Box(args=[0.1, 0.1, 0.1], position=[0, 0, 0], key="box"),
Box(args=[0.1, 0.1, 0.1], position=[0, 0, -0.5], key="far-box"),
up=[0, 1, 0],
grid=True,
rawChildren=[
OrthographicCamera(
key="ortho-camera",
left=-100, # Left boundary
right=100, # Right boundary
top=100, # Top boundary
bottom=-100, # Bottom boundary
near=1,
far=100,
position=[0, 3, 5],
lookAt=[0, 0, 0],
makeDefault=True,
),
],
)
await session.forever()
Key parameters: left, right, top, bottom (define view boundaries), near, far, position, lookAt, makeDefault
When to use:
CAD and technical drawings
2D games with isometric view
Data visualization where size consistency matters
Blueprint or schematic visualization
Camera Properties Reference¶
Scene vs DefaultScene¶
Scene: Minimal base class with emptybgChildren. Use when you need full control.DefaultScene: Includes sensible defaults (Grid, HemisphereLightStage, Gamepad, Hands, MotionControllers, SceneCamera, SceneCameraControl, CameraPreviewThumbs, CameraPreviewOverlay).
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
|
Up vector for the scene |
|
|
|
Background children components |
|
|
|
Show ground grid (DefaultScene only) |
PerspectiveCamera¶
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
75 |
Vertical field of view (degrees) |
|
|
0.1 |
Near clipping plane distance |
|
|
1000 |
Far clipping plane distance |
|
|
|
Camera position in 3D space |
|
|
|
Camera rotation (radians) |
|
|
- |
Point camera toward this position |
|
|
1 |
Zoom level multiplier |
|
|
False |
Set as the active camera |
OrthographicCamera¶
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
-1 |
Left boundary of view frustum |
|
|
1 |
Right boundary of view frustum |
|
|
1 |
Top boundary of view frustum |
|
|
-1 |
Bottom boundary of view frustum |
|
|
0.1 |
Near clipping plane distance |
|
|
1000 |
Far clipping plane distance |
|
|
|
Camera position in 3D space |
|
|
|
Camera rotation (radians) |
|
|
- |
Point camera toward this position |
|
|
1 |
Zoom level multiplier |
|
|
False |
Set as the active camera |
OrbitControls¶
Control Settings:
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
False |
Enable smooth damping (inertia) |
|
|
True |
Allow rotation/orbiting |
|
|
True |
Allow zoom in/out |
|
|
True |
Allow panning |
|
|
True |
Pan in screen space vs. camera space |
|
|
True |
Set as default controls |
Distance Limits:
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
0 |
Minimum zoom distance |
|
|
1000 |
Maximum zoom distance |
Angle Limits (degrees):
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
0 |
Minimum vertical angle (0-180) |
|
|
135 |
Maximum vertical angle (0-180) |
Speed Settings:
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
1.0 |
Rotation speed multiplier |
|
|
1.0 |
Zoom speed multiplier |
|
|
1.0 |
Pan speed multiplier |
Server Integration:
Property |
Type |
Default |
Description |
|---|---|---|---|
|
|
False |
Report camera move events to server |
What’s Next?¶
Now that you understand camera control basics, you can:
Continue with rendering:
Lights - Illuminate your scenes properly
Render Modes - Learn about different rendering modes
Post-processing Effects - Add bloom and visual effects
Path Tracing - Create photorealistic renders
Advanced camera features (for later exploration):
Virtual Camera Tutorial - Programmable cameras for off-screen rendering and multi-view displays