Loading...
Searching...
No Matches
AdventureCore.IDamageReceiver Interface Reference

Detailed Description

interface for any behaviour that receives damage from a IDamageSender
check TriggerDamageReceiver and TriggerDamageSender for a common implementation that can in turn be built upon

Inheritance diagram for AdventureCore.IDamageReceiver:
AdventureCore.ICharacterAssociator AdventureCore.CharacterBase AdventureCore.TriggerDamageReceiver AdventureCore.CharacterBaseTyped< TActor, TMovement, TInventory > AdventureCore.DestructibleDamageReceiver AdventureCore.MovableDamageReceiver AdventureCore.AnimatedCharacterBase< TActor, TMovement, TInventory > AdventureSouls.SoulsCharacterBase< TActor, TMovement, TInventory >

Public Member Functions

Vector3 GetPosition ()
 position of the receiver, may be used to determine damage direction
 
bool PreDamage (IDamageSender sender)
 called before any real damage handling to check if the handling is valid and should continue
for example if a character is currently dodging damage handling can be cancelled here
 
void OnDamage (DamageEvent e)
 this is where the main damage handling should take place and damage vectors are assigned
OnDamage is called in the order Sender > Receiver > Damage
for example if a character is wearing protective gear it may reduce the damage value here
this method is called for every damage parameter see DamageEvent for more details
 
void PostDamage (IDamageSender sender, List< DamageEvent > events)
 called after alle the damages have been applied
this is a good spot to react to the change of state that has been done by the damages
for example death or destruction if health was reduced to 0 by the damages
 

Additional Inherited Members

- Properties inherited from AdventureCore.ICharacterAssociator
CharacterBase AssociatedCharacter [get]
 character that owns or is otherwise associted with the object
 

Member Function Documentation

◆ GetPosition()

Vector3 AdventureCore.IDamageReceiver.GetPosition ( )

position of the receiver, may be used to determine damage direction

Returns
position of the receiver, or the character associated with it

Implemented in AdventureCore.TriggerDamageReceiver.

◆ OnDamage()

void AdventureCore.IDamageReceiver.OnDamage ( DamageEvent e)

this is where the main damage handling should take place and damage vectors are assigned
OnDamage is called in the order Sender > Receiver > Damage
for example if a character is wearing protective gear it may reduce the damage value here
this method is called for every damage parameter see DamageEvent for more details

Parameters
e

Implemented in AdventureCore.TriggerDamageReceiver.

◆ PostDamage()

void AdventureCore.IDamageReceiver.PostDamage ( IDamageSender sender,
List< DamageEvent > events )

called after alle the damages have been applied
this is a good spot to react to the change of state that has been done by the damages
for example death or destruction if health was reduced to 0 by the damages

Parameters
sender
events

Implemented in AdventureCore.DestructibleDamageReceiver, AdventureCore.MovableDamageReceiver, and AdventureCore.TriggerDamageReceiver.

◆ PreDamage()

bool AdventureCore.IDamageReceiver.PreDamage ( IDamageSender sender)

called before any real damage handling to check if the handling is valid and should continue
for example if a character is currently dodging damage handling can be cancelled here

Parameters
sender
Returns
whether the damage handling should continue

Implemented in AdventureCore.TriggerDamageReceiver.