GUI API#

class viser.GuiApi[source]#

Interface for working with the 2D GUI in viser.

Used by both our global server object, for sharing the same GUI elements with all clients, and by individual client handles.

reset() None[source]#

Reset the GUI.

Return type:

None

set_panel_label(label: str | None) None[source]#

Set the main label that appears in the GUI panel.

Parameters:

label (str | None) – The new label.

Return type:

None

configure_theme(*, titlebar_content: TitlebarConfig | None = None, control_layout: Literal[‘floating’, ‘collapsible’, ‘fixed’] = 'floating', control_width: Literal[‘small’, ‘medium’, ‘large’] = 'medium', dark_mode: bool = False, show_logo: bool = True, show_share_button: bool = True, brand_color: tuple[int, int, int] | None = None) None[source]#

Configures the visual appearance of the viser front-end.

Parameters:
  • titlebar_content (TitlebarConfig | None) – Optional configuration for the title bar.

  • control_layout (Literal[‘floating’, ‘collapsible’, ‘fixed’]) – The layout of control elements, options are “floating”, “collapsible”, or “fixed”.

  • control_width (Literal[‘small’, ‘medium’, ‘large’]) – The width of control elements, options are “small”, “medium”, or “large”.

  • dark_mode (bool) – A boolean indicating if dark mode should be enabled.

  • show_logo (bool) – A boolean indicating if the logo should be displayed.

  • show_share_button (bool) – A boolean indicating if the share button should be displayed.

  • brand_color (tuple[int, int, int] | None) – An optional tuple of integers (RGB) representing the brand color.

Return type:

None

add_folder(label: str, order: float | None = None, expand_by_default: bool = True, visible: bool = True) GuiFolderHandle[source]#

Add a folder, and return a handle that can be used to populate it.

Parameters:
  • label (str) – Label to display on the folder.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

  • expand_by_default (bool) – Open the folder by default. Set to False to collapse it by default.

  • visible (bool) – Whether the component is visible.

Returns:

A handle that can be used as a context to populate the folder.

Return type:

GuiFolderHandle

add_modal(title: str, order: float | None = None) GuiModalHandle[source]#

Show a modal window, which can be useful for popups and messages, then return a handle that can be used to populate it.

Parameters:
  • title (str) – Title to display on the modal.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used as a context to populate the modal.

Return type:

GuiModalHandle

add_tab_group(order: float | None = None, visible: bool = True) GuiTabGroupHandle[source]#

Add a tab group.

Parameters:
  • order (float | None) – Optional ordering, smallest values will be displayed first.

  • visible (bool) – Whether the component is visible.

Returns:

A handle that can be used as a context to populate the tab group.

Return type:

GuiTabGroupHandle

add_markdown(content: str, image_root: Path | None = None, order: float | None = None, visible: bool = True) GuiMarkdownHandle[source]#

Add markdown to the GUI.

Parameters:
  • content (str) – Markdown content to display.

  • image_root (Path | None) – Optional root directory to resolve relative image paths.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

  • visible (bool) – Whether the component is visible.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiMarkdownHandle

add_plotly(figure: go.Figure, aspect: float = 1.0, order: float | None = None, visible: bool = True) GuiPlotlyHandle[source]#

Add a Plotly figure to the GUI. Requires the plotly package to be installed.

Parameters:
  • figure (go.Figure) – Plotly figure to display.

  • aspect (float) – Aspect ratio of the plot in the control panel (width/height).

  • order (float | None) – Optional ordering, smallest values will be displayed first.

  • visible (bool) – Whether the component is visible.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiPlotlyHandle

add_button(label: str, disabled: bool = False, visible: bool = True, hint: str | None = None, color: Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None = None, icon: IconName | None = None, order: float | None = None) GuiButtonHandle[source]#

Add a button to the GUI. The value of this input is set to True every time it is clicked; to detect clicks, we can manually set it back to False.

Parameters:
  • label (str) – Label to display on the button.

  • visible (bool) – Whether the button is visible.

  • disabled (bool) – Whether the button is disabled.

  • hint (str | None) – Optional hint to display on hover.

  • color (Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None) – Optional color to use for the button.

  • icon (IconName | None) – Optional icon to display on the button.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiButtonHandle

add_upload_button(label: str, disabled: bool = False, visible: bool = True, hint: str | None = None, color: Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None = None, icon: IconName | None = None, mime_type: str = '*/*', order: float | None = None) GuiUploadButtonHandle[source]#

Add a button to the GUI. The value of this input is set to True every time it is clicked; to detect clicks, we can manually set it back to False.

Parameters:
  • label (str) – Label to display on the button.

  • visible (bool) – Whether the button is visible.

  • disabled (bool) – Whether the button is disabled.

  • hint (str | None) – Optional hint to display on hover.

  • color (Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None) – Optional color to use for the button.

  • icon (IconName | None) – Optional icon to display on the button.

  • mime_type (str) – Optional MIME type to filter the files that can be uploaded.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiUploadButtonHandle

add_button_group(label: str, options: Sequence[TLiteralString], visible: bool = True, disabled: bool = False, hint: str | None = None, order: float | None = None) GuiButtonGroupHandle[TLiteralString][source]#
add_button_group(label: str, options: Sequence[TString], visible: bool = True, disabled: bool = False, hint: str | None = None, order: float | None = None) GuiButtonGroupHandle[TString]

Add a button group to the GUI.

Parameters:
  • label – Label to display on the button group.

  • options – Sequence of options to display as buttons.

  • visible – Whether the button group is visible.

  • disabled – Whether the button group is disabled.

  • hint – Optional hint to display on hover.

  • order – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

add_checkbox(label: str, initial_value: bool, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[bool][source]#

Add a checkbox to the GUI.

Parameters:
  • label (str) – Label to display on the checkbox.

  • initial_value (bool) – Initial value of the checkbox.

  • disabled (bool) – Whether the checkbox is disabled.

  • visible (bool) – Whether the checkbox is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[bool]

add_text(label: str, initial_value: str, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[str][source]#

Add a text input to the GUI.

Parameters:
  • label (str) – Label to display on the text input.

  • initial_value (str) – Initial value of the text input.

  • disabled (bool) – Whether the text input is disabled.

  • visible (bool) – Whether the text input is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[str]

add_number(label: str, initial_value: IntOrFloat, min: IntOrFloat | None = None, max: IntOrFloat | None = None, step: IntOrFloat | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[IntOrFloat][source]#

Add a number input to the GUI, with user-specifiable bound and precision parameters.

Parameters:
  • label (str) – Label to display on the number input.

  • initial_value (IntOrFloat) – Initial value of the number input.

  • min (IntOrFloat | None) – Optional minimum value of the number input.

  • max (IntOrFloat | None) – Optional maximum value of the number input.

  • step (IntOrFloat | None) – Optional step size of the number input. Computed automatically if not specified.

  • disabled (bool) – Whether the number input is disabled.

  • visible (bool) – Whether the number input is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[IntOrFloat]

add_vector2(label: str, initial_value: tuple[float, float] | ndarray, min: tuple[float, float] | ndarray | None = None, max: tuple[float, float] | ndarray | None = None, step: float | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[tuple[float, float]][source]#

Add a length-2 vector input to the GUI.

Parameters:
  • label (str) – Label to display on the vector input.

  • initial_value (tuple[float, float] | ndarray) – Initial value of the vector input.

  • min (tuple[float, float] | ndarray | None) – Optional minimum value of the vector input.

  • max (tuple[float, float] | ndarray | None) – Optional maximum value of the vector input.

  • step (float | None) – Optional step size of the vector input. Computed automatically if not

  • disabled (bool) – Whether the vector input is disabled.

  • visible (bool) – Whether the vector input is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[tuple[float, float]]

add_vector3(label: str, initial_value: tuple[float, float, float] | ndarray, min: tuple[float, float, float] | ndarray | None = None, max: tuple[float, float, float] | ndarray | None = None, step: float | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[tuple[float, float, float]][source]#

Add a length-3 vector input to the GUI.

Parameters:
  • label (str) – Label to display on the vector input.

  • initial_value (tuple[float, float, float] | ndarray) – Initial value of the vector input.

  • min (tuple[float, float, float] | ndarray | None) – Optional minimum value of the vector input.

  • max (tuple[float, float, float] | ndarray | None) – Optional maximum value of the vector input.

  • step (float | None) – Optional step size of the vector input. Computed automatically if not

  • disabled (bool) – Whether the vector input is disabled.

  • visible (bool) – Whether the vector input is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[tuple[float, float, float]]

add_dropdown(label: str, options: Sequence[TLiteralString], initial_value: TLiteralString | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiDropdownHandle[TLiteralString][source]#
add_dropdown(label: str, options: Sequence[TString], initial_value: TString | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiDropdownHandle[TString]

Add a dropdown to the GUI.

Parameters:
  • label – Label to display on the dropdown.

  • options – Sequence of options to display in the dropdown.

  • initial_value – Initial value of the dropdown.

  • disabled – Whether the dropdown is disabled.

  • visible – Whether the dropdown is visible.

  • hint – Optional hint to display on hover.

  • order – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

add_progress_bar(value: float, visible: bool = True, animated: bool = False, color: Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None = None, order: float | None = None) GuiProgressBarHandle[source]#

Add a progress bar to the GUI.

Parameters:
  • value (float) – Value of the progress bar. (0 - 100)

  • visible (bool) – Whether the progress bar is visible.

  • animated (bool) – Whether the progress bar is in a loading state (animated, striped).

  • color (Literal[‘dark’, ‘gray’, ‘red’, ‘pink’, ‘grape’, ‘violet’, ‘indigo’, ‘blue’, ‘cyan’, ‘green’, ‘lime’, ‘yellow’, ‘orange’, ‘teal’] | None) – The color of the progress bar.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiProgressBarHandle

add_slider(label: str, min: IntOrFloat, max: IntOrFloat, step: IntOrFloat, initial_value: IntOrFloat, marks: tuple[IntOrFloat | tuple[IntOrFloat, str], ] | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[IntOrFloat][source]#

Add a slider to the GUI. Types of the min, max, step, and initial value should match.

Parameters:
  • label (str) – Label to display on the slider.

  • min (IntOrFloat) – Minimum value of the slider.

  • max (IntOrFloat) – Maximum value of the slider.

  • step (IntOrFloat) – Step size of the slider.

  • initial_value (IntOrFloat) – Initial value of the slider.

  • marks (tuple[IntOrFloat | tuple[IntOrFloat, str], ] | None) – tuple of marks to display below the slider. Each mark should either be a numerical or a (number, label) tuple, where the label is provided as a string.

  • disabled (bool) – Whether the slider is disabled.

  • visible (bool) – Whether the slider is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[IntOrFloat]

add_multi_slider(label: str, min: IntOrFloat, max: IntOrFloat, step: IntOrFloat, initial_value: tuple[IntOrFloat, ], min_range: IntOrFloat | None = None, fixed_endpoints: bool = False, marks: tuple[IntOrFloat | tuple[IntOrFloat, str], ] | None = None, disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[tuple[IntOrFloat, ...]][source]#

Add a multi slider to the GUI. Types of the min, max, step, and initial value should match.

Parameters:
  • label (str) – Label to display on the slider.

  • min (IntOrFloat) – Minimum value of the slider.

  • max (IntOrFloat) – Maximum value of the slider.

  • step (IntOrFloat) – Step size of the slider.

  • initial_value (tuple[IntOrFloat, ]) – Initial values of the slider.

  • min_range (IntOrFloat | None) – Optional minimum difference between two values of the slider.

  • fixed_endpoints (bool) – Whether the endpoints of the slider are fixed.

  • marks (tuple[IntOrFloat | tuple[IntOrFloat, str], ] | None) – tuple of marks to display below the slider. Each mark should either be a numerical or a (number, label) tuple, where the label is provided as a string.

  • disabled (bool) – Whether the slider is disabled.

  • visible (bool) – Whether the slider is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[tuple[IntOrFloat, …]]

add_rgb(label: str, initial_value: tuple[int, int, int], disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[tuple[int, int, int]][source]#

Add an RGB picker to the GUI.

Parameters:
  • label (str) – Label to display on the RGB picker.

  • initial_value (tuple[int, int, int]) – Initial value of the RGB picker.

  • disabled (bool) – Whether the RGB picker is disabled.

  • visible (bool) – Whether the RGB picker is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[tuple[int, int, int]]

add_rgba(label: str, initial_value: tuple[int, int, int, int], disabled: bool = False, visible: bool = True, hint: str | None = None, order: float | None = None) GuiInputHandle[tuple[int, int, int, int]][source]#

Add an RGBA picker to the GUI.

Parameters:
  • label (str) – Label to display on the RGBA picker.

  • initial_value (tuple[int, int, int, int]) – Initial value of the RGBA picker.

  • disabled (bool) – Whether the RGBA picker is disabled.

  • visible (bool) – Whether the RGBA picker is visible.

  • hint (str | None) – Optional hint to display on hover.

  • order (float | None) – Optional ordering, smallest values will be displayed first.

Returns:

A handle that can be used to interact with the GUI element.

Return type:

GuiInputHandle[tuple[int, int, int, int]]