Options
All
  • Public
  • Public/Protected
  • All
Menu

Concrete 3D World, a WorldManager setting out 3D-specific properties and behavior, providing type safety for Aura3D

NB: the default 3D Camera uses Perspective Projection

NB: World (0,0,0) is considered to be in the center, with: - positive X -> right - positive Y -> up - positive Z -> "out" ...and World coordinate limits: - left : -dimensions.x / 2 - right : dimensions.x / 2 - bottom : -dimensions.y / 2 - top : dimensions.y / 2 - far : -dimensions.z / 2 - near : dimensions.z / 2

Hierarchy

Index

Constructors

  • Constructor. Pass a 3D WorldConfig to the parent class and initialise the default 3D Camera

    Parameters

    Returns World

Properties

activeCamera: Camera

Concrete 3D active Camera

cameras: Map<string, Camera> = ...

Concrete mapping of named 3D Cameras

config: WorldConfig & { name: string }

Accessors

  • get dimensions(): Vec3
  • Get the 3D World dimensions

    Returns Vec3

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

    Returns number

    the number of active Entities

Methods

  • addCamera(camera: Camera): void
  • Add a 2D Camera to the World

    Parameters

    • camera: Camera

      the 3D Camera to add

    Returns void

  • 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

  • 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

  • getCamera(name: string): Camera
  • Retrieve a named 3D Camera

    Throws an error if the Camera is not found for runtime safety

    Parameters

    • name: string

      the name of the 3D Camera to retrieve

    Returns Camera

    the named 3D Camera

  • removeCamera(name: string): void
  • Remove a Camera by name

    Parameters

    • name: string

      the name of the Camera to remove

    Returns void

  • 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

  • switchToCamera(name: string): void
  • Switch to the named Camera

    Throws an error if the desired Camera is not found for runtime safety

    Parameters

    • name: string

      the name of the Camera to switch to

    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