-
Notifications
You must be signed in to change notification settings - Fork 4
Components
First see Entity Component System and Entities.
A component contains a piece of functionality that can be used across entities. Some examples include:
-
InputComponent
: Creates user input events on the entity, to which other components can react. -
RenderComponent
: Renders the entity to the screen. -
CombatComponent
: Gives health and attack stats to an entity. -
AITaskComponent
: Runs AI tasks on an NPC such as enemies. -
TerrainComponent
: Renders the map terrain on the screen.
All components should extend from the base Component class.
A component's lifecycle is the nearly same as the entity to which it is attached (See Entity Lifecycle). When an entity is created, updated, or disposed, then create()
, update()
, and dispose()
are called on each component attached to that entity.
What should be put in a component's constructor, and what should go in the create()
function?
The constructor will be called when you create the component to add it to an entity. This can be before all components have been added, and before the entity is added to the game world. create()
does not get called until the entity is added to the world.
Basically: Only setting constructor parameters and some basic initialisation should be done in the constructor. Everything else, including calls to getComponent()
, should wait until the create()
call. If the order that you add components to an entity matters, you've done it wrong.
When an entity is disabled, its components are not updated. However, components can be independently enabled/disabled as well. By disabling one or more components while keeping the entity enabled, we can modify that entity's behaviour during gameplay.
Camera Angle and The Player's Perspective
Achievements Trophies and Cards
πΎ Obstacle/Enemy
βMonster Manual
βObstacles/Enemies
ββ- Alien Plants
ββ- Variation thorns
ββ- Falling Meteorites
ββ- FaceHugger
ββ- AlienMonkey
βSpaceship & Map Entry
βParticle effect
[code for debuff animations](code for debuff animations)
Main Character Movement, Interactions and Animations - Code Guidelines
ItemBar & Recycle system
πΎ Obstacle/Enemy
βObstacle/Enemy
βMonster Manual
βSpaceship Boss
βParticle effects
βOther Related Code
βUML & Sequence diagram of enemies/obstacles
Scoring System Implementation Explanation
Buff and Debuff Implementation
Infinite generating terrains Implementation Explanation
Game Over Screen and functions explaination
Buffer timer before game start
Rocks and woods layout optimization
Magma and nails code implementation
Guide: Adding Background music for a particular screen
History Scoreboard - Score Details
Listening for important events in the Achievements ecosystem
Hunger and Thirst icon code guidelines
Hunger and Thirst User Testing
Buff and Debuff Manual User Testing
The New Button User Test in Setting Page
The Main Menu Buttons User Testing
Infinite loop game and Terrain Testing
https://github.com/UQdeco2800/2021-ext-studio-2.wiki.git
πΎ Obstacle/Enemy
βObstacle testing
ββ- Alien Plants & Variation Thorns
ββ- Falling Meteorites
βEnemy testing
ββ- Alien Monkeys & Facehugger
ββ- Spaceship Boss
βMonster Manual
βParticle-effect
βPlayer attack testing
ββ- Player Attack
Sprint 1
Sprint 2
Sprint 3
Sprint 4
Changeable background & Buffer time testing
Game over screen test sprint 4
New terrain textures on bonus map test sprint 4
Achievements System, Game Records and Unlockable Chapters
Musics Implementation Testing plan