Skip to main content

taichi.ui.camera#

class taichi.ui.camera.Camera#

The Camera class.

You should also manually set the camera parameters like camera.position, camera.lookat, camera.up, etc. The default settings may not work for your scene.

Example:

>>> scene = ti.ui.Scene()  # assume you have a scene
>>>
>>> camera = ti.ui.Camera()
>>> camera.position(1, 1, 1) # set camera position
>>> camera.lookat(0, 0, 0) # set camera lookat
>>> camera.up(0, 1, 0) # set camera up vector
>>> scene.set_camera(camera)
>>>
>>> # you can also control camera movement in a window
>>> window = ti.ui.Window("GGUI Camera", res=(640, 480), vsync=True)
>>> camera.track_user_inputs(window, movement_speed=0.03, hold_key=ti.ui.RMB)
bottom(self, bottom)#

Set the offset of the bottom clipping plane in camera frustum.

Parameters:

bottom (taichi.types.primitive_types) – offset of the bottom clipping plane.

Example:

>>> camera.bottom(1.0)
fov(self, fov)#

Set the camera fov angle (field of view) in degrees.

Parameters:

fov (taichi.types.primitive_types) – Angle in range (0, 180).

Example:

>>> camera.fov(45)
get_projection_matrix(self, aspect)#

Get the projection matrix(in row major) of the camera.

Parameters:

aspect (taichi.types.primitive_types) – aspect ratio of the camera

Example:

>>> camera.get_projection_matrix(1080/720)
get_view_matrix(self)#

Get the view matrix(in row major) of the camera.

Example:

>>> camera.get_view_matrix()
left(self, left)#

Set the offset of the left clipping plane in camera frustum.

Parameters:

left (taichi.types.primitive_types) – offset of the left clipping plane.

Example:

>>> camera.left(-1.0)
lookat(self, x, y, z)#

Set the camera lookat.

Parameters:

args (taichi.types.primitive_types) – 3D coordinates.

Example:

>>> camera.lookat(0, 0, 0)
position(self, x, y, z)#

Set the camera position.

Parameters:

args (taichi.types.primitive_types) – 3D coordinates.

Example:

>>> camera.position(1, 1, 1)
projection_mode(self, mode)#

Camera projection mode, 0 for perspective and 1 for orthogonal.

right(self, right)#

Set the offset of the right clipping plane in camera frustum.

Parameters:

right (taichi.types.primitive_types) – offset of the right clipping plane.

Example:

>>> camera.right(1.0)
top(self, top)#

Set the offset of the top clipping plane in camera frustum.

Parameters:

top (taichi.types.primitive_types) – offset of the top clipping plane.

Example:

>>> camera.top(-1.0)
track_user_inputs(self, window, movement_speed: float = 1.0, yaw_speed: float = 2.0, pitch_speed: float = 2.0, hold_key=None)#

Move the camera according to user inputs. Press w, s, a, d, e, q to move the camera formard, back, left, right, head up, head down, accordingly.

Parameters:
  • window (Window) – a windown instance.

  • movement_speed (primitive_types) – camera movement speed.

  • yaw_speed (primitive_types) – speed of changes in yaw angle.

  • pitch_speed (primitive_types) – speed of changes in pitch angle.

  • hold_key (ui) – User defined key for holding the camera movement.

up(self, x, y, z)#

Set the camera up vector.

Parameters:

args (taichi.types.primitive_types) – 3D coordinates.

Example:

>>> camera.up(0, 1, 0)
z_far(self, z_far)#

Set the offset of the far clipping plane in camera frustum.

Parameters:

far (taichi.types.primitive_types) – offset of the far clipping plane.

Example:

>>> camera.left(1000.0)
z_near(self, z_near)#

Set the offset of the near clipping plane in camera frustum.

Parameters:

near (taichi.types.primitive_types) – offset of the near clipping plane.

Example:

>>> camera.near(0.1)