All Classes and Interfaces
Class
Description
This component is used to create action feedback alerts based on Entity events.
Chases a target entity until they get too far away or line of sight is lost.
Waits around for a set amount of time and then fires a projectile at a target.
Task-based AI component.
A custom UIComponent used which displays text within a yellow border for alerts.
Cast a ray against all colliders that match the layer mask.
Renders animations from a texture atlas on an entity.
Class that contains data on all the entities for a given game area
Basic Asteroid properties for Space Obstacle minigame to be loaded by obstacle factory
Class to create weapons when the player attacks
Defines a basic set of properties stored in entities config files to be loaded by Entity Factories.
A tool which allows the player to place a basic wall.
POJO which contains the custom data attached to each box2D entity.
BossTask controls actions of the Boss Entity.
Chases a target entity until they get too far away or line of sight is lost
Attaches a physics collider to an entity.
This class is used to programmatically create a color which can be used as a background in UI components.
Component used to store information related to combat such as health, attack, etc.
A generic command class.
This class represents the action component for interacting with a Companion entity.
This class represents the animation controller component for a companion entity.
Defines the properties stored in Companion config files to be loaded by the Companion Factory.
The screen displayed when the companion character dies in the game.
This class defines the actions to be taken when the companion character dies in the game.
Factory to create a companion entity.
CompanionInventoryComponent handles all the inventory management for the companion.
A UI component for displaying Companion stats, e.g., health.
Core component class from which all components inherit.
Internal type system for components.
A component that defines actions and event listeners for the Controls Screen.
A UI component responsible for displaying the controls screen's user interface.
Used to charge the player resources when a structure is placed and refund
the player resources when a structure is picked up.
A Rendering component used to switch between different textures based on the current entity's health.
When this entity (usually killable entities) has health = 0, it disposes the
enemy form the field of play.
This class listens to events relevant to the Death Screen and does something when one of the
events is triggered.
The UI component responsible for rendering and managing the death screen interface.
A command for toggling debug mode on and off.
Provides functionality to draw lines/shapes to the screen for debug purposes.
A default task implementation that stores the associated entity and updates status when
starting/stopping a task.
A custom dialog box for displaying in-game dialogues with an OK button.
Class for creating the UI Component
for displaying distance
This class listens to events relevant to all enemy entities' state and plays the animation when one
of the events is triggered.
Determines the enemy behaviour on what target to prioritise.
Defines the properties stored in Enemy config files to be loaded by the NPC Factory.
Defines the properties stored in Enemy config files to be loaded by the NPC Factory.
Factory to create non-playable enemies entities with predefined components.
Determines the enemy type of whether it is a:
Melee (small melee enemy)
Ranged (small ranged enemy)
BossMelee (Boss melee enemy)
BossRanged (Boss ranged enemy)
Core entity class.
Service to allow entities to be placed after game initilisation
Code is a modified version of StructurePlacementServic written by team 7
Kept Seperate due to differences in implementation and functionality
Provides a global access point for entities to register themselves.
When this entity touches a valid enemy's hitbox, deal damage to them and apply a knockback.
Factory to create all environmental entities on the map
Component used to store information related to combat such as health, attack, etc.
Send and receive events between objects.
An event listener which is notified when events occur.
An event listener with 0 arguments
An event listener with 1 argument
An event listener with 2 arguments
An event listener with 3 arguments
Exit button but specified for the Shop implementation only
This class listens to events relating to the state of the extractor and plays
the extracting animation when the broken extractor is fixed, otherwise the broken
extractor remains 'un-animated'.
This is a window that can be added to a stage to pop up for the extractor minigame.
Wrapper for reading Java objects from JSON files.
FOVComponent
This component is used to detect enemies within a certain radius of the turret.
Represents an area in the game, such as a level, indoor area, etc.
Displays the name of the current game area.
Represents the current state of the game whilst ensuring thread safety.
Callback interface to be implemented by classes interested in
receiving notifications about state changes.
A utility interaction class to manage and modify game state
The global game state observer class (EventHandler) that allows components
to interface with the stored game state data using event calls and triggers.
Controls the game time
Entry point of the non-platform-specific game logic.
Contains additional utility constants and functions for common GridPoint2 operations.
A ui component for displaying an entities health at its location on the map.
Physics comp
An interface which defines the ability to change the alpha of a render.
The initial screen of the game, responsible for loading assets and creating UI elements.
The user interface component responsible for displaying the initial story sequence.
An InputComponent that supports keyboard and touch input and touch gestures.
Generic class to wrap an InputProcessor so that it acts like an InputComponent.
InputFactory creates inputType-specific inputFactories which can handle various types of input.
Input device types
Class to override any input components being handled.
Provides a global access point for handling user input and creating input handlers.
A tool which allows the player to place an intermediate wall or upgrade basic walls.
A component intended to be used by the player to track their inventory.
Represents the display component for the player's inventory in the game.
A component responsible for handling item pickups in the game.
A job system provides a general-purpose way to run multi-threaded code.
This component is used to change the texture and collision bounds of an entity
depending on its neighbours.
This component is used to change the texture and collision bounds of an entity
depending on its neighbours.
This class is used to read-in and store the vertices for entities
with a JoinableComponent attached.
This class is used to read-in and store the vertices for entities
with a JoinableComponent attached.
Used by JoinableComponent to pass around the direction of
a join between elements.
Used by JoinableComponent to pass around the direction of
a join between elements.
Used by JoinableComponent to check if two entities should be joined.
Used by JoinableComponent to check if two entities should be joined.
The KeyboardCompanionInputComponent class handles keyboard input for controlling a companion character.
KeyboardInputFactory creates input handlers that process keyboard and touch support.
d
Input handler for the player for keyboard and touch (mouse) input.
Input handler for the ship for keyboard.
Input handler for the debug terminal for keyboard and touch (mouse) input.
The LaboratoryFactory class is responsible for creating laboratory entities in the game.
LaboratoryInventoryComponent handles the inventory of a laboratory,
specifically the number of potions it contains.
This is a window that can be added to a stage to pop up for the extractor Laboratory.
This class listens to events relevant to the Main Game Screen and does something when one of the
events is triggered.
Displays a button to exit the Main Game screen to the Main Menu screen.
This class listens to events relevant to the Main Menu Screen and does something when one of the
events is triggered.
The UI component responsible for rendering and managing the main menu interface.
The game screen containing the main menu.
Class to handle loading of game areas from config files
A Base Game Area for any level.
The MiniScreen class represents a screen in the game that displays a mini-screen with initial content.
The MiniScreenDisplay class represents a user interface component used in the initial sequence of the game.
A movement controller moves something to a given a target.
Move to a given position, finishing when you get close enough.
Defines all NPC configs to be loaded by Related Factories.
Factory to create non-playable character (NPC) entities with predefined components.
Factory to create obstacle entities.
This config class is used to load in custom sound files to play using the SoundComponent
Displays performance stats about the game for debugging purposes.
Lets an entity be controlled by physics.
Box2D collision events fire globally on the physics world, not per-object.
Process game physics using the Box2D library.
Movement controller for a physics-based entity.
Provides a global access point to the physics engine.
This interface defines methods components can implement which will be called when a structure
is placed or removed via the StructurePlacementService.
An abstract tool which allows the player to place a structure.
Displays the name of the current game area and an image of the planet.
A screen that represents a single planet of the game with its corresponding game area/s.
Responsible for travel between planets and stored the number of planets remaining
Action component for interacting with the player.
This class listens to events relevant to a player's state and plays the animation when one
of the events is triggered.
Defines the properties stored in player config files to be loaded by the Player Factory.
The game screen indicating a player's death and options to either restart or exit game.
Factory to create a player entity.
An ui component for displaying player stats, e.g.
Class to create weapons for the player to hold
Portal class which extends Entity.
Factory to create Portal entities.
Represents a power-up component within the game.
This UI Component for displaying PowerUp.
A priority task is a task that also has a priority.
When this entity touches a valid enemy's hitbox, deal damage to them and apply a knockback.
Factory to create projectile entities with predefined components.
Projectile moves towards the target in a straight line and is disposed once it reaches the target position
This component can be used to call an entry or exit method when on of the tracking
entities enters or exits a proximity.
Stores information about a raycast hit.
Can be rendered onto the screen given a Sprite batch.
A generic component for rendering an entity.
Core rendering system for the game.
Globally accessible service for registering renderable components.
An abstract tool which allows the player to place a structure.
A ui component for displaying resources in the bottom right corner of the screen.
Service for loading resources, e.g.
Displays a button to exit the current game screen to the current Planet screen.
Used by the RotationRenderComponent to indicate which atlasRegion to display.
This component can be used to display different AtlasRegions depending on the
compass rotation of the entity.
Runs away from target entity if it gets too close
A simplified implementation of the Service Locator pattern:
https://martinfowler.com/articles/injection.html#UsingAServiceLocator
Settings menu display and logic.
The game screen containing the settings.
Action component for interacting with the player.
This class listens to events relevant to a ship's state and plays the animation
when one of the events is triggered
A ui component for displaying the ship stats, e.g.
Represents the upgrades for ship
contains types of upgrades for ships
Shoots a projectile at a target in game.
Shop Area for spawning items and stats about the ship
Cast a ray against all colliders that match the layermask.
A map sorted by the value of key with O(1) iteration.
This component can be used to trigger sounds by an entity to play.
This config class is used to load in custom sound files to play using the SoundComponent
Forest area for the demo game with trees, a player, and some enemies.
The game screen containing the main game.
The SpaceMiniTransition class represents a screen transition effect used in a LibGDX game.
Represents the navigation screen for the game, allowing the user to navigate
between various planets and options.
Fires Boss' Special Attack
A component that defines actions for managing the game's story progression.
A UI component that displays a sequence of images along with navigation buttons for a story presentation.
The game screen containing the main game.
Apply a custom toString() for a class without overriding the class, using a decorator.
This component can be placed on PlaceableEntities and will destroy the structure
if it runs out of health.
Factory to create structure entities - such as extractors or ships.
This component can be placed onto the player and allows them to select and interact
with structure tools.
An AI task can be started and stopped at any time.
State tracker for a debug terminal.
A ui component for displaying the debug terminal.
Render a tiled terrain for a given tiled map and orientation.
Factory for creating game terrains.
This enum should contain the different terrains in your game, e.g.
Custom terrain tile implementation for tiled map terrain that stores additional properties we
may want to have in the game, such as audio, walking speed, traversability by AI, etc.
Render a static texture.
A tool which can be selected via the StructureToolPicker and can be interacted with by the player.
This class is used to read in the structure tools config file.
This class is used to read in the structure tools config file.
TouchAttackComponent is responsible for dealing damage and applying knockback to entities when
this entity collides with a valid enemy's hitbox.
TouchCompanionInputComponent handles touch input to control a companion character.
Input handler for the player for keyboard and touch (mouse) input.
Input handler for the debug terminal for keyboard and touch (mouse) input.
Turret
This class is used to create a turret entity.
This class is used to configure the Turret entity.
This component allows a turret to target the entity it is placed on.
A tool which allows the player to place a turret.
This enum is used to represent the different types of turrets.
A generic component for rendering onto the ui.
The UpgradeDisplay class represents a GUI component for displaying upgrades.
Represents a node within the upgrade tree.
Represents the screen for the Shop that user can select items to upgrade their spaceship.
Represents the upgrade tree component for the game, which manages weapon upgrades.
Reading, Writing, and applying user settings in the game.
Stores chosen display settings.
Stores game settings, can be serialised/deserialised.
Contains additional utility constants and functions for common Vector2 operations.
Task that does nothing other than waiting for a given time.
Core wall class.
Defines each entries properties stored in wall config file to be loaded by the Wall Factory.
Defines the properties stored in walls config files to be loaded by the Wall Factory.
WallType enum.
Represents a task that causes the entity to wander around by moving to random positions within a specified range of its starting position.
Class to implement weapon functionality in the player,
Acts as the central component for weapons being to
respond to an enemy attack use an attack factory to generate a weapon entity
Defines each entries properties stored in wall config file to be loaded by the Wall Factory.
Class to return weapon configs
Class to control the movement of weapons that have been spawned