Package gaiasky.scene
Class Scene
java.lang.Object
gaiasky.scene.Scene
Represents a scene, contains and manages the engine. The engine contains
and manages all entities and systems in the world.
-
Field Summary
-
Constructor Summary
-
Method Summary
Modifier and TypeMethodDescriptionvoid
addSystemsToEngine
(com.badlogic.gdx.utils.Array<?> systems) void
addToIndex
(com.badlogic.ashley.core.Entity entity) Inserts the given entity into the index by running the index initializer system on it.Access to the archetypes.void
Constructs the scene graph structure in theGraphNode
components of the current entities.void
disable
(com.badlogic.ashley.core.EntitySystem... systems) Disable the given entity systems.void
disable
(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Disable the given entity systems.void
enable
(com.badlogic.ashley.core.EntitySystem... systems) Enable the given entity systems.void
enable
(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Enable the given entity systems.void
extractEntity
(com.badlogic.ashley.core.Entity entity) Runs the matching extract systems on the given entity.com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity>
findEntitiesByComponentType
(ComponentTypes.ComponentType componentType, com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity> list) com.badlogic.ashley.utils.ImmutableArray<com.badlogic.ashley.core.Entity>
findEntitiesByFamily
(com.badlogic.ashley.core.Family family) com.badlogic.ashley.core.Entity
Returns the focus entity with the given name, if it exists.com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity>
Returns a list with all the entities which are focusable.com.badlogic.ashley.core.Entity
Returns the entity with the given name, or null if it does not exist.com.badlogic.ashley.core.Entity
getLineCopy
(com.badlogic.ashley.core.Entity entity) int
getNumberObjects
(com.badlogic.ashley.core.Entity entity) Returns the number of actual objects held by this entity.int
getNumberObjects
(OctreeNode node) Computes the number of objects in the given octree node, recursively.double[]
getObjectPosition
(String name, double[] out) Gets the current position of the object identified by the given name.com.badlogic.ashley.core.Entity
getSimpleCopy
(com.badlogic.ashley.core.Entity entity) index()
Access to the index.void
void
Sets up the initializing systems and runs them.void
initializeEntity
(com.badlogic.ashley.core.Entity entity) Runs the matching initialization systems on the given entity.void
Initializes the name and id index using the current entities.void
insert
(com.badlogic.ashley.core.Entity entity, boolean addToIndex) void
matchingFocusableNodes
(String name, SortedSet<String> results, int maxResults, AtomicBoolean abort) Returns focus entities matching the given string by name, to a maximum ofmaxResults
.void
prepareUpdateSystems
(ISceneRenderer sceneRenderer) Prepares the engine to start running update cycles.void
remove
(com.badlogic.ashley.core.Entity entity, boolean removeFromIndex) Removes the given entity from the scene.void
void
returnCopyObject
(com.badlogic.ashley.core.Entity copy) void
runOnce
(com.badlogic.ashley.core.EntitySystem... systems) Runs the given entity systems only once with a dummy delta time of 0.void
runOnce
(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Runs the given entity systems only once with a dummy delta time of 0.void
Runs the set up initialization stage for all entities.void
setUpEntity
(com.badlogic.ashley.core.Entity entity) Runs the matching setup systems on the given entity.void
update
(ITimeFrameProvider time) Updates the scene.void
updateEntity
(com.badlogic.ashley.core.Entity entity, float deltaTime) Runs the matching update systems on the given entity.void
updateEntityGraph
(com.badlogic.ashley.core.Entity entity, ITimeFrameProvider time, Vector3b parentTranslation, float opacity) Updates the entity graph for the given entity with the given parent translation vector.void
Updates the localized names of all entities in the scene.
-
Field Details
-
ROOT_NAME
- See Also:
-
engine
public com.badlogic.ashley.core.Engine engineThe engine, containing all entities, components and systems.
-
-
Constructor Details
-
Scene
public Scene()
-
-
Method Details
-
index
Access to the index. -
archetypes
Access to the archetypes. -
initialize
public void initialize() -
runOnce
public void runOnce(com.badlogic.ashley.core.EntitySystem... systems) Runs the given entity systems only once with a dummy delta time of 0. Useful for running one-time initialization and loading tasks.- Parameters:
systems
- The systems to run.
-
runOnce
public void runOnce(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Runs the given entity systems only once with a dummy delta time of 0. Useful for running one-time initialization and loading tasks.- Parameters:
array
- The systems array to run.
-
enable
public void enable(com.badlogic.ashley.core.EntitySystem... systems) Enable the given entity systems.- Parameters:
systems
- The systems.
-
enable
public void enable(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Enable the given entity systems.- Parameters:
array
- The systems.
-
disable
public void disable(com.badlogic.ashley.core.EntitySystem... systems) Disable the given entity systems.- Parameters:
systems
- The systems.
-
disable
public void disable(com.badlogic.gdx.utils.Array<? extends com.badlogic.ashley.core.EntitySystem> array) Disable the given entity systems.- Parameters:
array
- The systems.
-
initializeEntities
public void initializeEntities()Sets up the initializing systems and runs them. These systems perform the initial entity initialization. -
setUpEntities
public void setUpEntities()Runs the set up initialization stage for all entities. This happens when all asset loading has finished. -
addSystemsToEngine
public void addSystemsToEngine(com.badlogic.gdx.utils.Array<?> systems) -
initializeIndex
public void initializeIndex()Initializes the name and id index using the current entities. -
addToIndex
public void addToIndex(com.badlogic.ashley.core.Entity entity) Inserts the given entity into the index by running the index initializer system on it.- Parameters:
entity
- The entity.
-
buildSceneGraph
public void buildSceneGraph()Constructs the scene graph structure in theGraphNode
components of the current entities. -
prepareUpdateSystems
Prepares the engine to start running update cycles. This method initializes the engine with all the necessary update systems. -
initializeEntity
public void initializeEntity(com.badlogic.ashley.core.Entity entity) Runs the matching initialization systems on the given entity. The systems are matched using their families.- Parameters:
entity
- The entity to initialize.
-
setUpEntity
public void setUpEntity(com.badlogic.ashley.core.Entity entity) Runs the matching setup systems on the given entity. The systems are matched using their families.- Parameters:
entity
- The entity to set up.
-
updateEntity
public void updateEntity(com.badlogic.ashley.core.Entity entity, float deltaTime) Runs the matching update systems on the given entity. The systems are matched using their families.- Parameters:
entity
- The entity to update.
-
extractEntity
public void extractEntity(com.badlogic.ashley.core.Entity entity) Runs the matching extract systems on the given entity. The systems are matched using their families.- Parameters:
entity
- The entity to update.
-
updateEntityGraph
public void updateEntityGraph(com.badlogic.ashley.core.Entity entity, ITimeFrameProvider time, Vector3b parentTranslation, float opacity) Updates the entity graph for the given entity with the given parent translation vector. Use with caution, this may have unforeseen consequences, as the process usually updates the whole scene graph starting at the root. This by-passes the usual procedure to update a single entity and its subtree.- Parameters:
entity
- The entity to update.time
- The time object.parentTranslation
- The parent translation.opacity
- The opacity value.
-
update
Updates the scene. This causes an update to the engine.- Parameters:
time
- The time frame provider object.
-
insert
public void insert(com.badlogic.ashley.core.Entity entity, boolean addToIndex) -
remove
public void remove(com.badlogic.ashley.core.Entity entity, boolean removeFromIndex) Removes the given entity from the scene.- Parameters:
entity
- The entity.removeFromIndex
- Whether to remove it from the index too.
-
updateLocalizedNames
public void updateLocalizedNames()Updates the localized names of all entities in the scene. -
getEntity
Returns the entity with the given name, or null if it does not exist.- Parameters:
name
- The name of the entity to retrieve.- Returns:
- The entity.
-
findFocus
Returns the focus entity with the given name, if it exists.- Parameters:
name
- The name.- Returns:
- The entity.
-
matchingFocusableNodes
public void matchingFocusableNodes(String name, SortedSet<String> results, int maxResults, AtomicBoolean abort) Returns focus entities matching the given string by name, to a maximum ofmaxResults
.- Parameters:
name
- The name.results
- The set where the results are to be stored.maxResults
- The maximum number of results.abort
- To enable abortion mid-computation.
-
findFocusableEntities
public com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity> findFocusableEntities()Returns a list with all the entities which are focusable.- Returns:
- A list with all focusable entities in this scene.
-
findEntitiesByFamily
public com.badlogic.ashley.utils.ImmutableArray<com.badlogic.ashley.core.Entity> findEntitiesByFamily(com.badlogic.ashley.core.Family family) -
findEntitiesByComponentType
public com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity> findEntitiesByComponentType(ComponentTypes.ComponentType componentType, com.badlogic.gdx.utils.Array<com.badlogic.ashley.core.Entity> list) -
getObjectPosition
Gets the current position of the object identified by the given name. The given position is in the internal reference system and corrects stars for proper motions and other objects for their specific motions as well.- Parameters:
name
- The name of the objectout
- The out double array- Returns:
- The out double array if the object exists, has a position and out has 3 or more slots. Null otherwise.
-
getFamilies
-
getLineCopy
public com.badlogic.ashley.core.Entity getLineCopy(com.badlogic.ashley.core.Entity entity) -
getSimpleCopy
public com.badlogic.ashley.core.Entity getSimpleCopy(com.badlogic.ashley.core.Entity entity) -
returnCopyObject
public void returnCopyObject(com.badlogic.ashley.core.Entity copy) -
reportDebugObjects
public void reportDebugObjects() -
getNumberObjects
public int getNumberObjects(com.badlogic.ashley.core.Entity entity) Returns the number of actual objects held by this entity. Most entities count as only one object, but some, such as particle and star sets, orbital element sets or octrees, actually hold and wrap many objects.- Parameters:
entity
- The entity.- Returns:
- The number of objects it holds.
-
getNumberObjects
Computes the number of objects in the given octree node, recursively.- Parameters:
node
- The node.- Returns:
- The number of objects.
-