Class ThreeViewer

Three Viewer

The ThreeViewer is the main class in the framework to manage a scene, render and add plugins to it.

Hierarchy

Constructors

Properties

_canvas: HTMLCanvasElement
_canvasTexture?: CanvasTexture & ITexture
_container: HTMLElement
_defaultConfig: ISerializedViewerConfig = ...
_isRenderingFrame: boolean = false
_lastCameraPosition: Vector3 = ...
_lastCameraQuat: Quaternion = ...
_lastCameraTarget: Vector3 = ...
_lastSize: Vector2 = ...
_needsReset: boolean = true
_needsResize: boolean = false
_objectProcessor: IObjectProcessor = ...
_scene: RootScene

The Scene attached to the viewer, this cannot be changed.

_tempQuat: Quaternion = ...
_tempVec: Vector3 = ...
assetManager: AssetManager
debug: boolean
enabled: boolean = true

If the viewer is enabled. Set this false to disable RAF loop.

maxFramePerLoop: number = 1

Specifies how many frames to render in a single request animation frame. Keep to 1 for realtime rendering. Note: should be max (screen refresh rate / animation frame rate) like 60Hz / 30fps

plugins: Record<string, IViewerPlugin<ThreeViewer, boolean>> = {}
renderEnabled: boolean = true

Enable or disable all rendering, Animation loop including any frame/render events won't be fired when this is false.

renderManager: ViewerRenderManager
renderStats: GLStatsJS
rendersPerFrame: number = 1

Number of times to run composer render. If set to more than 1, preRender and postRender events will also be called multiple times.

resizeObserver: undefined | ResizeObserver = ...

The ResizeObserver observing the canvas element. Add more elements to this observer to resize viewer on their size change.

type: "ThreeViewer" = 'ThreeViewer'
uiConfig: UiObjectConfig<any, string, any>
ConfigTypeSlug: "vjson" = 'vjson'
Console: IConsoleWrapper = ...
Dialog: IDialogWrapper = windowDialogWrapper
VERSION: "0.0.26" = VERSION
ViewerDebugging: boolean = false

If any of the viewers are in debug mode, this will be true. This is required for debugging/logging in some cases.

Accessors

  • get canvas(): HTMLCanvasElement
  • Get the HTML Canvas Element where the viewer is rendering

    Returns HTMLCanvasElement

Methods

  • Add a plugin to the viewer.

    Type Parameters

    Parameters

    • plugin: T | Class<T>

      The instance of the plugin to add or the class of the plugin to add.

    • Rest ...args: any[]

      Arguments for the constructor of the plugin, in case a class is passed.

    Returns Promise<T>

    • The plugin added.
  • Disposes the viewer and frees up all resource and events. Do not use the viewer after calling dispose.

    Returns void

    Note

    • If you want to reuse the viewer, set viewer.enabled to false instead, then set it to true again when required. To dispose all the objects, materials in the scene use viewer.scene.disposeSceneModels() This function is not fully implemented yet. There might be some memory leaks.

    Todo

    • return promise?
  • Type Parameters

    • TRet

    Parameters

    • event: "update" | "dispose" | "preRender" | "postRender" | "preFrame" | "postFrame" | "*" | "addPlugin" | "renderEnabled" | "renderDisabled"
    • Optional func: ((...args) => TRet)
        • (...args): TRet
        • Parameters

          • Rest ...args: any[]

          Returns TRet

    Returns Promise<undefined | TRet>

  • Uses the FileTransferPlugin to export a blob. If the plugin is not available, it will download the blob. FileTransferPlugin can be configured by other plugins to export the blob to a specific location like local file system, cloud storage, etc.

    Parameters

    • blob: Blob | File

      The blob or file to export/download

    • Optional name: string

    Returns Promise<void>

  • Serialize all the viewer and plugin settings.

    Parameters

    • binary: boolean = false

      Indicate that the output will be converted and saved as binary data. (default: false)

    • Optional pluginFilter: string[]

      List of PluginType to include. If empty, no plugins will be serialized. If undefined, all plugins will be serialized.

    Returns ISerializedViewerConfig

  • Parameters

    • Optional selected: Object3D<Event, string>
    • distanceMultiplier: number = 1.5
    • Optional duration: number
    • Optional ease: "linear" | Easing | "easeIn" | "easeOut" | "easeInOut" | "circIn" | "circOut" | "circInOut" | "backIn" | "backOut" | "backInOut" | "anticipate" | "bounceOut" | "bounceIn" | "bounceInOut" | "easeInOutSine"

    Returns Promise<void>

  • Get the Plugin by a constructor type or add a new plugin of the specified type if it doesn't exist.

    Type Parameters

    Parameters

    • type: Class<T>
    • Rest ...args: any[]

      arguments for the constructor of the plugin, used when a new plugin is created.

    Returns Promise<T>

  • Get the Plugin by a constructor type or add a new plugin to the viewer of the specified type if it doesn't exist(sync).

    Type Parameters

    Parameters

    • type: Class<T>
    • Rest ...args: any[]

      arguments for the constructor of the plugin, used when a new plugin is created.

    Returns T

  • Get the Plugin by a constructor type or by the string type. Use string type if the plugin is not a dependency and you don't want to bundle the plugin.

    Type Parameters

    Parameters

    • type: string | Class<T>

      The class of the plugin to get, or the string type of the plugin to get which is in the static PluginType property of the plugin

    Returns undefined | T

    • The plugin of the specified type.
  • Parameters

    • __namedParameters: {
          mimeType: undefined | string;
          quality: undefined | number;
      } = {}
      • mimeType: undefined | string
      • quality: undefined | number

    Returns Promise<undefined | null | Blob>

  • Parameters

    • __namedParameters: {
          mimeType: undefined | string;
          quality: undefined | number;
      } = {}
      • mimeType: undefined | string
      • quality: undefined | number

    Returns Promise<undefined | null | string>

  • Mark that the canvas is resized. If the size is changed, the renderer and all render targets are resized. This happens before the render of the next frame.

    Returns void

  • Serialize all the plugins and their settings to save or create presets. Used in toJSON.

    Parameters

    • meta: SerializationMetaType

      The meta object.

    • Optional filter: string[]

      List of PluginType for the to include. If empty, no plugins will be serialized. If undefined, all plugins will be serialized.

    Returns any[]

  • Set the viewer to dirty and trigger render of the next frame.

    Parameters

    • Optional source: any

      The source of the dirty event. like plugin or 3d object

    • Optional event: Event

      The event that triggered the dirty event.

    Returns void

  • Set the render size of the viewer to fit in the container according to the specified mode, maintaining aspect ratio. Changes the renderScale accordingly. Note: the canvas needs to be centered in the container to work properly, this can be done with the following css on the container:

    display: flex;
    justify-content: center;
    align-items: center;

    or in js:

    viewer.container.style.display = 'flex';
    viewer.container.style.justifyContent = 'center';
    viewer.container.style.alignItems = 'center';

    Modes: 'contain': The canvas is scaled to fit within the container while maintaining its aspect ratio. The canvas will be fully visible, but there may be empty space around it. 'cover': The canvas is scaled to fill the entire container while maintaining its aspect ratio. Part of the canvas may be clipped to fit the container. 'fill': The canvas is stretched to completely fill the container, ignoring its aspect ratio. 'scale-down': The canvas is scaled down to fit within the container while maintaining its aspect ratio, but it won't be scaled up if it's smaller than the container. 'none': container size is ignored, but devicePixelRatio is used

    Parameters

    • size: {
          height: number;
          width: number;
      }

      The size to set the render to. The canvas will render to this size.

      • height: number
      • width: number
    • mode: "fill" | "none" | "contain" | "cover" | "scale-down" = 'contain'

      'contain', 'cover', 'fill', 'scale-down' or 'none'. Default is 'contain'.

    • devicePixelRatio: number = 1

      typically set to window.devicePixelRatio, or Math.min(1.5, window.devicePixelRatio) for performance. Use this only when size is derived from dom elements.

    • Optional containerSize: {
          height: number;
          width: number;
      }

      (optional) The size of the container, if not passed, the bounding client rect of the container is used.

      • height: number
      • width: number

    Returns void

  • Set size of the canvas and update the renderer. If no size or width/height is passed, canvas is set to 100% of the container.

    See also ThreeViewer.setRenderSize to set the size of the render target by automatically calculating the renderScale and fitting in container.

    Note: Apps using this should ideally set max-width: 100% for the canvas in css.

    Parameters

    • Optional size: {
          height?: number;
          width?: number;
      }
      • Optional height?: number
      • Optional width?: number

    Returns void

  • Serialize all the viewer and plugin settings and versions.

    Parameters

    • binary: boolean = true

      Indicate that the output will be converted and saved as binary data. (default: true)

    • Optional pluginFilter: string[]

      List of PluginType to include. If empty, no plugins will be serialized. If undefined, all plugins will be serialized.

    Returns ISerializedViewerConfig

    • Serializable JSON object.

Generated using TypeDoc