-
Notifications
You must be signed in to change notification settings - Fork 1
Animal Health System
The Animal Health System in our game provides a comprehensive framework for managing Non-Player Character (NPC) health, death animations, and health bar visualization. This system enhances the game's visual feedback and contributes to a more immersive player experience.
The CombatStatsComponent
is the core component that manages the health and combat-related statistics for both NPCs and the player.
- Manages health, max health, and attack values
- Handles damage calculations and health modifications
- Triggers events when an entity dies
The NPCDeathHandler
component manages the death process for NPCs.
- Plays a death animation when the NPC's health reaches zero
- Disables physics, AI, hitbox, and collider components upon death
- Removes the entity from the game after the death animation completes
- Triggers events for player score and coin collection
The NPCHealthBarComponent
renders a visual health bar above NPCs.
- Displays current health as a percentage of maximum health
- Uses color-coding (red for empty, green for filled) for intuitive visualization
-
Health Management:
- The
CombatStatsComponent
manages the NPC's health. - When health reaches zero, it triggers the "died" event.
- The
-
Death Handling:
- The
NPCDeathHandler
listens for the "died" event. - Upon death, it plays the death animation, disables physics and AI, and schedules the entity's removal.
- It also triggers events for player score and coin collection.
- The
-
Health Bar Visualization:
- The
NPCHealthBarComponent
continuously renders the health bar above the NPC. - It calculates the health percentage and draws a proportional green bar over a red background.
- The
classDiagram
class Component {
+create()
+update()
+dispose()
}
class CombatStatsComponent {
-int health
-int maxHealth
-int baseAttack
+getHealth()
+setHealth(int)
+hit(CombatStatsComponent)
}
class NPCDeathHandler {
-boolean isDead
-Entity target
-int npcStrength
+onDeath()
}
class NPCHealthBarComponent {
-ShapeRenderer shapeRenderer
+draw(SpriteBatch)
}
class Entity {
+addComponent(Component)
+getComponent(Class)
}
Component <|-- CombatStatsComponent
Component <|-- NPCDeathHandler
Component <|-- NPCHealthBarComponent
Entity "1" *-- "many" Component : has
sequenceDiagram
participant Player
participant NPC
participant CombatStats
participant DeathHandler
participant HealthBar
Player->>NPC: Attacks
NPC->>CombatStats: Receive damage
CombatStats->>CombatStats: Update health
CombatStats->>HealthBar: Update display
alt Health <= 0
CombatStats->>DeathHandler: Trigger "died" event
DeathHandler->>NPC: Play death animation
DeathHandler->>NPC: Disable components
DeathHandler->>Player: Update score/coins
DeathHandler->>NPC: Remove entity (after delay)
end
To integrate these components into an NPC entity:
- Add the components to your NPC entity creation method:
Entity createNPC(Entity player, int strength) {
return new Entity()
.addComponent(new CombatStatsComponent(100, 10)) // health, attack
.addComponent(new NPCDeathHandler(player, strength))
.addComponent(new NPCHealthBarComponent())
// ... other components
}
-
Ensure your NPC entity has an
AnimationRenderComponent
with a "death" animation for the death sequence to work properly. -
Make sure to call the
draw()
method ofNPCHealthBarComponent
in your rendering loop.
- Modularity: The separation of combat stats, death handling, and health bar rendering into distinct components allows for easy reuse and maintenance.
-
Performance: The use of
ShapeRenderer
for health bars is efficient for rendering multiple NPCs. - Extensibility: The current design allows for easy addition of new features, such as different types of status effects or more complex health systems.
-
Enhanced Death Handling: The
NPCDeathHandler
now disables multiple components (AI, physics, hitbox, collider) when the NPC dies, ensuring comprehensive cleanup. -
Coin Collection Integration: Upon NPC death, a "collectCoin" event is triggered with the NPC's strength as the parameter, allowing for dynamic reward systems.
-
Centralized Entity Disposal: Entity removal now uses the
GameAreaService
, providing a more centralized and consistent approach to entity management. -
Improved Health Bar Rendering: The
NPCHealthBarComponent
now uses a more efficient rendering approach, improving performance for games with many NPCs.
These changes have resulted in a more robust, performant, and visually appealing system for managing NPC health and providing feedback to the player. The revised architecture allows for easier expansion and maintenance of the Animal Health System, aligning well with our goals of creating an immersive and responsive game environment.
Design Choices
Utilities
Animals
Menus/screens
Character
- Character Animations
- Character's Inventory On Display
- Character's Inventory System
- Character's HealthBar
- Character's Interaction with Items
- Character achievements
- Saving Character
- Player-(and-other-NPC)-invincibility-frames
- Player Factory
- Scoring System
- Test Plan for Inventory System
- Test Plan for Player's Interaction with Items
- Test Plan for Player's Inventory Display
- Test Plan for Saving Character State
- Test Plan for Scoring System
Map
Weapon
- Weapon Overview
- Weapon Types
- Weapon Structure
- Weapon Stats Display
- Testing Plan for Weapon Factory
- Testing Plan for Firing Controller Component
- Testing Plan for Position Tracker Component
- Testing Plan for Weapon Animation Controller component
- Testing Plan for Concrete Melee Weapon class
- Testing Plan for Concrete Ranged Weapon class