Options
All
  • Public
  • Public/Protected
  • All
Menu

Concrete 2D UI, a UIManager setting out 3D-specific properties and behavior, providing type safety for Aura3D

Hierarchy

Index

Constructors

  • Constructor. Pass a type-correct 2D or 3D UIConfig to the parent class

    Parameters

    • config: UIConfig

      the type-correct 2D or 3D UIConfig

    Returns UI

Properties

config: UIConfig & { name: string }

Accessors

  • get entityCount(): number
  • Retrieve the number of Entities in play

    Returns number

    the number of active Entities

Methods

  • addEntities(...entities: Entity[]): void
  • Prepare a list of Entities to be added to the Game on the next frame

    Parameters

    • Rest ...entities: Entity[]

      the Entities to add

    Returns void

  • addEntity(entity: Entity): void
  • Prepare an Entity to be added to the Game on the next frame

    Parameters

    • entity: Entity

      the Entity to add

    Returns void

  • Add a 3D Panel to the UI

    Parameters

    • position: Vec3

      the 3D position of the Panel

    • scale: Vec3

      the 3D scale of the Panel

    • color: Color

      the Color of the Panel

    Returns void

  • clearEntities(): void
  • Purge all active Entities immediately

    Returns void

  • filterEntitiesByComponentName(component: string): Entity[]
  • Filter the active Entities by a given Component name. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • component: string

      the name of the Component to filter by

    Returns Entity[]

    the list of Entities with the Component

  • filterEntitiesByComponentNameFromSource(source: Entity[], filterId: string, component: string): Entity[]
  • Filter Entities from a given source by a given Component name. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • source: Entity[]

      the Entity list to treat as the filter source

    • filterId: string

      an identifier for the filter result, used to avoid conflicts for similar filters across disparate sources

    • component: string

    Returns Entity[]

    the list of Entities from the source with the Component

  • filterEntitiesByComponentNames(...components: string[]): Entity[]
  • Filter the active Entities by a given list of Component names. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • Rest ...components: string[]

      the names of the Components to filter by

    Returns Entity[]

    the list of Entities with the Components

  • filterEntitiesByComponentNamesFromSource(source: Entity[], filterId: string, ...components: string[]): Entity[]
  • Filter the Entities from a given source by a given list of Component names. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • source: Entity[]

      the Entity list to treat as the filter source

    • filterId: string

      an identifier for the filter result, used to avoid conflicts for similar filters across disparate sources

    • Rest ...components: string[]

      the names of the Components to filter by

    Returns Entity[]

    the list of Entities from the source with the Components

  • filterEntitiesByTag(tag: string): Entity[]
  • Filter the active Entities by a given tag. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • tag: string

      the tag to filter by

    Returns Entity[]

    the list of Entities with the tag

  • filterEntitiesByTags(...tags: string[]): Entity[]
  • Filter the active Entities by a given list of tags. Filter results are cached to optimise frame-to-frame filters

    Parameters

    • Rest ...tags: string[]

      the tags to filter by

    Returns Entity[]

    the list of Entities with the tags

  • removeEntities(...entities: Entity[]): void
  • Prepare a list of Entities to be removed from the Game on the next frame

    Parameters

    • Rest ...entities: Entity[]

      the Entities to remove

    Returns void

  • removeEntity(entity: Entity): void
  • Prepare an Entity to be removed from the Game on the next frame

    Parameters

    • entity: Entity

      the Entity to remove

    Returns void

  • render(): void
  • Frame render method. Render all active and renderable Entities.

    Processes Entities grouped by shader+model combinations so as to reduce the amount of GL buffering required and render in batches

    Returns void

  • tick(game: GameBase, frameDelta: number): void
  • Frame update method. Process the Entity addList and removeList, then run all active Entities' frame update methods

    Parameters

    • game: GameBase

      the Game the EntityManager is running within

    • frameDelta: number

      the frame delta as calculated by the Game

    Returns void