Event Handlers – Arma 2

From Bohemia Interactive Community
m (Text replacement - " (https:\/\/[a-zA-Z0-9.\/\_\-]+) " to " {{Link|$1}} ")
 
(31 intermediate revisions by 8 users not shown)
Line 1: Line 1:
=Introduction=
{{TOC|side}}
An event handler (abbreviated to EH) allows you to automatically monitor and then execute custom code upon particular events being triggered.
An event handler (abbreviated to EH) allows to automatically monitor and then execute custom code upon particular events being triggered.
{{Feature|warning|
As opposed to {{ofp}} event handlers, in {{arma2}} a respawned unit retains the EHs it had before, so it is no longer required to re-add EHs after respawning.
}}


These event handlers relate to commands such as: [[addEventHandler]], [[removeEventHandler]], [[removeAllEventHandlers]].


== General MP Note ==
See also: [[Event Scripts]] for special event triggered scripts.


As opposed to OFP event handlers, in ArmA 2 a respawned unit retains the EHs it had before, so it is no longer required to re-add EHs after respawning.


The new MP event handler "MPHit" and "MPKilled" have to be assigned to the object by using [[addMPEventHandler]].
== Event Handlers List ==


== Event Scripts ==
Related commands:
See also: [[Event Scripts]] for special event triggered scripts.
* [[addEventHandler]]
* [[removeEventHandler]]
* [[removeAllEventHandlers]]


=Event Handler List=
=== AnimChanged ===


== AnimChanged ==
Triggered every time a new animation is started.
Trigerred everytime a new animation is started.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[unit, anim]'''
Passed array: '''[unit, anim]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* anim: [[String]] - Name of the anim that is given by playMove/switchMove/playAction/switchAction<br />
* anim: [[String]] - Name of the anim that is given by playMove/switchMove/playAction/switchAction
 
=== AnimDone ===


== AnimDone ==
Triggered every time an animation is finished.
Trigerred everytime an animation is finished.


Unknown MP behaviour. Probably local.
Unknown MP behaviour. Probably local.
Line 32: Line 35:
Passed array: '''[unit, anim]'''
Passed array: '''[unit, anim]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* anim: [[String]] - Name of the anim that has been finished<br />
* anim: [[String]] - Name of the anim that has been finished


==AnimStateChanged==
=== AnimStateChanged ===
[[Image:Arma2_1.00.gif]] Available in Arma 2 only.<br />
 
Trigerred everytime an animation state changes. Unlike AnimChanged and AnimDone, it is triggered for all animation states in a sequence.  
Triggered every time an animation state changes. Unlike AnimChanged and AnimDone, it is triggered for all animation states in a sequence.


Unknown MP behaviour. Probably local.
Unknown MP behaviour. Probably local.
Line 43: Line 46:
Passed array: '''[unit, anim]'''
Passed array: '''[unit, anim]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* anim: [[String]] - Name of the anim that has been started<br />
* anim: [[String]] - Name of the anim that has been started


== Dammaged ==  
=== Dammaged ===
Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP.


(If simultaneous damage occured (e.g. via grenade) EH might be triggered several times.)
Global. {{Icon|globalEffect|32}}
 
(If simultaneous damage occurred (e.g. via grenade) EH might be triggered several times.)


Passed array: '''[unit, selectionName, damage]'''
Passed array: '''[unit, selectionName, damage]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* selectionName: [[String]] - Name of the selection where the unit was damaged<br />
* selectionName: [[String]] - Name of the selection where the unit was damaged
* damage: [[Number]] - Resulting level of damage
* damage: [[Number]] - Resulting level of damage


== Engine ==  
=== Engine ===
 
Triggered when the engine of the unit is turned on/off.
Triggered when the engine of the unit is turned on/off.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[vehicle, engineState]'''
Passed array: '''[vehicle, engineState]'''


* vehicle: [[Object]] - Vehicle the event handler is assigned to <br />
* vehicle: [[Object]] - Vehicle the event handler is assigned to
* engineState: [[Boolean]] - True when the engine is turned on, false when turned off
* engineState: [[Boolean]] - True when the engine is turned on, false when turned off


==Fired==  
=== Fired ===
 
Triggered when the unit fires a weapon.


Triggered when the unit fires a weapon.<br>
This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle.
This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}
 
Passed array: '''[unit, weapon, muzzle, mode, ammo]'''


Passed array: '''[unit, weapon, muzzle, mode, ammo]''' <br />
b1.54.73642 : '''[unit, weapon, muzzle, mode, ammo, magazine, projectile]'''
b1.54.73642 : '''[unit, weapon, muzzle, mode, ammo, magazine, projectile]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* weapon: [[String]] - Fired weapon <br />
* weapon: [[String]] - Fired weapon
* muzzle: [[String]] - Muzzle that was used <br />
* muzzle: [[String]] - Muzzle that was used
* mode: [[String]] - Current mode of the fired weapon<br />
* mode: [[String]] - Current mode of the fired weapon
* ammo: [[String]] - Ammo used <br />
* ammo: [[String]] - Ammo used
* magazine [[String]] - magazine name which was used<br />
* magazine: [[String]] - magazine name which was used
* projectile [[object]] - Object of the projectile that was shot
* projectile: [[object]] - Object of the projectile that was shot
 
=== FiredNear ===
 
Triggered when a weapon is fired somewhere ''near'' the unit or vehicle.


==FiredNear==
[[Image:Arma2_1.00.gif]] Available in Arma 2 only.<br />
Triggered when a weapon is fired somewhere ''near'' the unit or vehicle.<br />
It is also triggered if the unit itself is firing.
It is also triggered if the unit itself is firing.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}
(Exception(s): the Throw weapon wont broadcast the FiredNear event)
{{Feature|important|Exception: the {{hl|Throw}} weapon will not broadcast the {{hl|FiredNear}} event.}}


Passed array: '''[unit, firer, distance, weapon, muzzle, mode, ammo]'''
Passed array: '''[unit, firer, distance, weapon, muzzle, mode, ammo]'''
Line 105: Line 113:
* ammo: [[String]] - Ammo used
* ammo: [[String]] - Ammo used


==Fuel==  
=== Fuel ===
 
Triggered when the unit's fuel status changes between completely empty / not empty (only useful if the event handler is assigned to a vehicle).
Triggered when the unit's fuel status changes between completely empty / not empty (only useful if the event handler is assigned to a vehicle).


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[vehicle, fuelState]'''
Passed array: '''[vehicle, fuelState]'''


* vehicle: [[Object]] - Vehicle the event handler is assigned to <br />
* vehicle: [[Object]] - Vehicle the event handler is assigned to
* fuelState: [[Boolean]] - 0 when no fuel, 1 when the fuel tank is full
* fuelState: [[Boolean]] - 0 when no fuel, 1 when the fuel tank is full
 
 
==Gear==  
=== Gear ===
 
Triggered when the unit lowers/retracts the landing gear (only useful if the event handler is assigned to is a member of the class "Plane").
Triggered when the unit lowers/retracts the landing gear (only useful if the event handler is assigned to is a member of the class "Plane").


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}
Passed array: '''[vehicle, gearState]'''
Passed array: '''[vehicle, gearState]'''


* vehicle: [[Object]] - Vehicle the event handler is assigned to <br />
* vehicle: [[Object]] - Vehicle the event handler is assigned to
* gearState: [[Boolean]] - True when the gear is lowered, false when retracted
* gearState: [[Boolean]] - True when the gear is lowered, false when retracted
 
 
==GetIn==  
=== GetIn ===
 
Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands.
Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[vehicle, position, unit]'''
Passed array: '''[vehicle, position, unit]'''
Line 135: Line 146:
* unit: [[Object]] - Unit that entered the vehicle
* unit: [[Object]] - Unit that entered the vehicle


==GetOut==  
=== GetOut ===
 
Triggered when a unit gets out from the object, works the same way as GetIn.
Triggered when a unit gets out from the object, works the same way as GetIn.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[vehicle, position, unit]'''
Passed array: '''[vehicle, position, unit]'''
Line 145: Line 157:
* position: [[String]] - Can be either "driver", "gunner", "commander" or "cargo"
* position: [[String]] - Can be either "driver", "gunner", "commander" or "cargo"
* unit: [[Object]] - Unit that leaved the vehicle
* unit: [[Object]] - Unit that leaved the vehicle
 
==HandleDamage==
[[Image:Arma2_1.00.gif]] Available in Arma 2 only.<br />


Triggered when the unit is damaged. Works with all vehicles. C
=== HandleDamage ===


ode provided must return a value what should be the damage of given part after processing.  
Triggered when the unit is damaged. Works with all vehicles.


Adding this eventhandler with no return value or with return value 0, replaces damage handling by the engine, making the object invulnerable if damage is not scripted in the eventhandler.  
Code provided must return a value what should be the damage of given part after processing.
If you want default processing to be done, be sure to return ''_this select 2''.  
 
Adding this eventhandler with no return value or with return value 0, replaces damage handling by the engine, making the object invulnerable if damage is not scripted in the eventhandler.
If you want default processing to be done, be sure to return ''_this select 2''.


You can [[setDamage]] and [[setHit]] in combination for additional damage handling.
You can [[setDamage]] and [[setHit]] in combination for additional damage handling.


'''Locality''': HandleDamage is triggered where the unit is local. See also [[Locality in Multiplayer]].
'''Locality''': HandleDamage is triggered where the unit is local. See also [[Locality in Multiplayer]].
Local. {{Icon|localEffect|32}}


This EH is triggered separately for every selection of the damaged object.
This EH is triggered separately for every selection of the damaged object.
Line 172: Line 185:


'''Example:'''
'''Example:'''
<pre>HANDLE = TargetSoldier addeventhandler ["HandleDamage",{diag_log text format ["T=%1 : %2", time, _this];_this select 2;} ];</pre>
<sqf>TargetSoldier addEventHandler ["HandleDamage", { diag_log text format ["T=%1 : %2", time, _this]; _this select 2; }];</sqf>


When shooting the soldier once in the head, and once in the torso, ArmA2.RPT shows:
When shooting the soldier once in the head, and once in the torso, ArmA2.RPT shows:
<pre>T=6.754 : [TargetSoldier,"",0.350463,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"head_hit",3.23586,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"body",0.0743558,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"hands",0.667459,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"legs",0.00307311,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"",0.350179,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"head_hit",0.230999,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"body",1.52881,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"hands",0.105206,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"legs",0.0211435,B 1-1-A:1 (Matthijs),"B_556x45_Ball"]</pre>


Link to explanation [http://forums.bistudio.com/showthread.php?t=113418&highlight=event+handler Celery's explanation]
T=6.754 : [TargetSoldier,"",0.350463,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"head_hit",3.23586,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"body",0.0743558,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"hands",0.667459,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"legs",0.00307311,SourceUnit,"B_556x45_Ball"]


==HandleHeal==
T=10.078 : [TargetSoldier,"",0.350179,SourceUnit,"B_556x45_Ball"]
[[Image:Arma2_1.00.gif]] Available in Arma 2 only.<br />
T=10.078 : [TargetSoldier,"head_hit",0.230999,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"body",1.52881,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"hands",0.105206,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"legs",0.0211435,SourceUnit,"B_556x45_Ball"]
 
See {{Link|link= http://forums.bistudio.com/showthread.php?t=113418&highlight=event+handler|text= Celery's explanation}}.
 
Notes:
* HandleDamage can trigger "twice" per damage event. Once for direct damage, once for indirect damage (explosive damage).
* This can happen even in the same frame, but is unlikely.
* Each HandleDamage event show the current damage from the damage source. '''NOT''' cumulative or the current "damage level" (health) of the target unit.
* So a second HandleDamage event can nullify/overwrite the damage of the first event, IF they are in the same frame (or time slice the engine uses the update the damage status of an unit).
* You can save the last event as timestamp ([[diag_tickTime]]) onto the unit, as well as the current health of the unit/it's selections, with [[setVariable]] and query it on each HandleDamage event with [[getVariable]] to define a system how to handle the new HandleDamage event.
 
// first HandleDamage event - direct damage by sabot hit onto an infantry unit
1081.55,[TargetUnit,"",6426.05,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"head_hit",441.609,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"body",333.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"hands",533.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"legs",533.333,SourceUnit,"Sh_120_SABOT"]
 
// second HandleDamage event - indirect damage by the impact - maybe force/friction applied to the unit body
1081.59,[TargetUnit,"",2.24228,TargetUnit,""]
1081.59,[TargetUnit,"head_hit",0.89672,TargetUnit,""]
1081.59,[TargetUnit,"body",3.3113,TargetUnit,""]
1081.59,[TargetUnit,"hands",3.74862,TargetUnit,""]
1081.59,[TargetUnit,"legs",10,TargetUnit,""]
 
=== HandleHeal ===


Triggered when unit starts to heal (player using heal action or AI heals after being ordered). If code returns false, engine side healing follows. Return true if you handle healing in script, use [[AISFinishHeal]] to tell engine that script side healing is done. See also [[lifeState]] and [[setUnconscious]] commands.
Triggered when unit starts to heal (player using heal action or AI heals after being ordered). If code returns false, engine side healing follows. Return true if you handle healing in script, use [[AISFinishHeal]] to tell engine that script side healing is done. See also [[lifeState]] and [[setUnconscious]] commands.
Line 199: Line 234:
* healercanheal: [[Boolean]] - true when healer is corpsman
* healercanheal: [[Boolean]] - true when healer is corpsman


==Hit==  
=== Hit ===
Triggered when the unit is hit/damaged.  
 
Triggered when the unit is hit/damaged.
 
Is ''not'' always triggered when unit is killed by a hit.
 
Most of the time only the [[ArmA:_Event_Handlers#Killed|killed]] event handler is triggered when a unit dies from a hit.


Is ''not'' always triggered when unit is killed by a hit.<br>Most of the time only the [[ArmA:_Event_Handlers#Killed|killed]] event handler is triggered when a unit dies from a hit.<br>The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.<br>Does not fire when a unit is set to allowDamage false.
The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.


Local. [[Image:effects_local.gif]]
Does not fire when a unit is set to allowDamage false.
 
Local. {{Icon|localEffect|32}}


Passed array: '''[unit, causedBy, damage]'''
Passed array: '''[unit, causedBy, damage]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* causedBy: [[Object]] - Object that caused the damage.<br />Contains the unit itself in case of collisions. <br />
* causedBy: [[Object]] - Object that caused the damage.<br>Contains the unit itself in case of collisions.
* damage: [[Number]] - Level of damage caused by the hit
* damage: [[Number]] - Level of damage caused by the hit


==Init==  
=== HitPart ===
Triggered on mission start or when a vehicle is created on the fly using [[createVehicle]].
 
'''WARNING:'''
{{Feature|important|
As of 2012-02-06, this eventhandler is fundamentally malfunctioning in dedicated multiplayer environments.
Make sure you see this ticket before you waste your time with it: {{Link|https://dev-heaven.net/issues/27837}} --[[User:Krause|Krause]] 04:53, 7 February 2012 (CET)
}}
 
Runs when the object, it was added to, gets injured/damaged.
It returns the position and component that was hit on the object within a nested array, this is because the model may have more than selection name for the hit component.
 
{{GVI|arma2oa|1.60}} Global. {{Icon|globalEffect|32}}
 
Passed array: '''<nowiki>[[target, shooter, bullet, position, velocity, selection, ammo, direction, radius, surface, direct]]</nowiki>'''


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
* target: [[Object]] - Object that got injured/damaged.
* shooter: [[Object]] - Unit that inflicted the damage. If injured by a vehicle impact or a fall the target itself is returned, or, in case of explosions, the [[objNull|null object]]. In case of explosives that were planted by someone (e.g. satchel charges), that unit is returned.
* bullet: [[Object]] - Object that was fired.
* position: [[Position#Introduction|Position3D]] - Position the bullet impacted (ASL).
* velocity: [[Vector3D]] - 3D speed at which bullet impacted.
* selection: [[Array]] - Array of [[String]]s with named selection of the object that were hit.
* ammo: [[Array]] - Ammo info: [hit value, indirect hit value, indirect hit range, explosive damage, ammo class name] OR, if there is no shot object: [impulse value on object collided with,0,0,0]
* direction: [[Vector3D]] - vector that is orthogonal (perpendicular) to the surface struck. For example, if a wall was hit, vector would be pointing out of the wall at a 90 degree angle.
* radius: [[Number]] - Radius (size) of component hit.
* surface: [[String]] - Surface type struck.
* direct: [[Boolean]] - [[true]] if object was directly hit, [[false]] if it was hit by indirect/splash damage.


Passed array: '''[unit]'''
=== IncomingMissile ===


* unit: [[Object]] - Object the event handler is assigned to
 
==IncomingMissile==
Triggered when a guided missile locked on the target or unguided missile or rocket aimed by AI at the target was fired.
Triggered when a guided missile locked on the target or unguided missile or rocket aimed by AI at the target was fired.


Global.   [[Image:effects_global.gif|Global effect EventHandler]]
Global. {{Icon|globalEffect|32}}


Passed array: '''[unit, ammo, whoFired]'''
Passed array: '''[unit, ammo, whoFired]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* ammo: [[String]] - Ammo type that was fired on the unit <br />
* ammo: [[String]] - Ammo type that was fired on the unit
* whoFired: [[Object]] - Object that fired the weapon
* whoFired: [[Object]] - Object that fired the weapon


==Killed==  
=== Init ===
 
Triggered on mission start or when a vehicle is created on the fly using [[createVehicle]].
 
Global. {{Icon|globalEffect|32}}
 
Passed array: '''[unit]'''
 
* unit: [[Object]] - Object the event handler is assigned to
 
=== Killed ===


Triggered when the unit is killed.
Triggered when the unit is killed.


Local. [[Image:effects_local.gif]]
Local. {{Icon|localEffect|32}}


Passed array: '''[unit, killer]'''
Passed array: '''[unit, killer]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* killer: [[Object]] - Object that killed the unit<br />Contains the unit itself in case of collisions. <br />
* killer: [[Object]] - Object that killed the unit<br>Contains the unit itself in case of collisions.


Be careful when the killer has been a vehicle. For most cases the reference of the vehicle is the same as the [[effectiveCommander]], yet not always. For example:
Be careful when the killer has been a vehicle. For most cases the reference of the vehicle is the same as the [[effectiveCommander]], yet not always. For example:


_gunner setVariable ["Variable",true];
<sqf>
_killer getVariable "Variable" => <null>
_gunner setVariable ["Variable",true];
(gunner (vehicle _killer)) getVariable "Variable" => true
_killer getVariable "Variable"; // <null>
(gunner (vehicle _killer)) getVariable "Variable"; // true
</sqf>


And sample debug output:  
And sample debug output:


_killer => B 1-2-F:2
<sqf>
(gunner (vehicle _killer)) => B 1-2-F:2
_killer; // B 1-2-F:2
((gunner (vehicle _killer)) == _killer) => false
(gunner (vehicle _killer)); // B 1-2-F:2
(gunner (vehicle _killer)) == _killer; // false
</sqf>


==LandedTouchDown==  
=== LandedStopped ===
Triggered when a plane (AI or player) touches the ground.
 
Triggered when an AI pilot would get out usually. Not executed for player.


Local. [[Image:effects_local.gif]]
Local. {{Icon|localEffect|32}}


Passed array: '''[plane, airportID]'''
Passed array: '''[plane, airportID]'''


* plane: [[Object]] - Object the event handler is assigned to <br />
* plane: [[Object]] - Object the event handler is assigned to
* airportID: [[Number]] - ID of the airport (-1 for anything else). <br />
* airportID: [[Number]] - ID of the airport (-1 for anything else).


==LandedStopped==  
=== LandedTouchDown ===
Triggered when an AI pilot would get out usually. Not executed for player.
 
Triggered when a plane (AI or player) touches the ground.


Local. [[Image:effects_local.gif]]
Local. {{Icon|localEffect|32}}


Passed array: '''[plane, airportID]'''
Passed array: '''[plane, airportID]'''


* plane: [[Object]] - Object the event handler is assigned to <br />
* plane: [[Object]] - Object the event handler is assigned to
* airportID: [[Number]] - ID of the airport (-1 for anything else). <br />
* airportID: [[Number]] - ID of the airport (-1 for anything else).
 
=== Respawn ===


==Respawn==
Triggered when a unit respawns.
Triggered when a unit respawns.


Passed array: '''[unit, corpse, ...]'''
Passed array: '''[unit, corpse, ...]'''


* unit: [[Object]] - Object the event handler is assigned to <br />
* unit: [[Object]] - Object the event handler is assigned to
* corpse: [[Object]] - Object the event handler was assigned to, aka the corpse/unit player was previously controlling. <br />
* corpse: [[Object]] - Object the event handler was assigned to, aka the corpse/unit player was previously controlling.
 
=== WeaponAssembled ===


==WeaponAssembled==
Triggers when weapon gets assembled.
Triggers when weapon gets assembled.


[[Image:arma2oa_1.55.gif]]Global.   [[Image:effects_global.gif|Global effect EventHandler]]
{{GVI|arma2oa|1.55}} Global. {{Icon|globalEffect|32}}


Passed array: '''[unit, weapon]'''
Passed array: '''[unit, weapon]'''


* unit: [[object]] - Object the event handler is assigned to <br />
* unit: [[object]] - Object the event handler is assigned to
* weapon: [[object]] - Object of the assembled weapon. <br />
* weapon: [[object]] - Object of the assembled weapon.
 
=== WeaponDisassembled ===


==WeaponDisassembled==
Triggers when weapon gets disassembled.
Triggers when weapon gets disassembled.


[[Image:arma2oa_1.55.gif]]Global.   [[Image:effects_global.gif|Global effect EventHandler]]
{{GVI|arma2oa|1.55}} Global. {{Icon|globalEffect|32}}


Passed array: '''[unit, primaryBag, secondarybag]'''
Passed array: '''[unit, primaryBag, secondarybag]'''


* unit: [[object]] - Object the event handler is assigned to <br />
* unit: [[object]] - Object the event handler is assigned to
* primaryBag: [[object]] - First backpack object which was weapon dissasembled into... <br />
* primaryBag: [[object]] - First backpack object which was weapon disassembled into...
* secondarybag: [[object]] - Second backpack object which was weapon dissasembled into... <br />
* secondarybag: [[object]] - Second backpack object which was weapon disassembled into...


==MPHit==
Triggered when the unit is hit/damaged.


Is ''not'' always triggered when unit is killed by a hit.<br>Most of the time only the [[ArmA:_Event_Handlers#Killed|killed]] event handler is triggered when a unit dies from a hit.<br>The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.<br>Does not fire when a unit is set to allowDamage false.
== Multiplayer Event Handlers List ==


[[Image:arma2oa_1.55.gif]]Global.   [[Image:effects_global.gif|Global effect EventHandler]]
The new MP event handlers "MPHit", "MPKilled" and "MPRespawn" have to be assigned to the object by using [[addMPEventHandler]].


Passed array: '''[unit, causedBy, damage]'''
Related commands:
* [[addMPEventHandler]]
* [[removeMPEventHandler]]
* [[removeAllMPEventHandlers]]
 
{{Feature|important|A Multiplayer Event Handler is '''not''' saved in a save file and therefore will not be restored on load - use it accordingly.}}
 
=== MPHit ===
 
Triggered when the unit is hit/damaged.
 
Is ''not'' always triggered when unit is killed by a hit.


* unit: [[Object]] - Object the event handler is assigned to <br />
Most of the time only the [[ArmA:_Event_Handlers#Killed|killed]] event handler is triggered when a unit dies from a hit.
* causedBy: [[Object]] - Object that caused the damage.<br />Contains the unit itself in case of collisions. <br />
* damage: [[Number]] - Level of damage caused by the hit


The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.


'''Notes:
Does not fire when a unit is set to allowDamage false.
'''
This command must be used in conjunction with the new command AddMPEventHandler rather than the old command used for non MP commands.


http://community.bistudio.com/wiki/addMPEventHandler
{{GVI|arma2oa|1.55}} Global. {{Icon|globalEffect|32}}


==MPKilled==
Passed array: '''[unit, causedBy, damage]'''
Triggered when the unit is killed.
 
* unit: [[Object]] - Object the event handler is assigned to
* causedBy: [[Object]] - Object that caused the damage.<br>Contains the unit itself in case of collisions.
* damage: [[Number]] - Level of damage caused by the hit


[[Image:arma2oa_1.55.gif]]Global.  [[Image:effects_global.gif|Global effect EventHandler]]
=== MPKilled ===


Passed array: '''[unit, killer]'''
Triggered when the unit is killed. This event handler is triggered for a disconnecting player, if "playableAI" are disabled (by admin or [[Description.ext]]), so that the playable unit dies on disconnect.


* unit: [[Object]] - Object the event handler is assigned to <br />
{{GVI|arma2oa|1.55}} Global. {{Icon|globalEffect|32}}
* killer: [[Object]] - Object that killed the unit<br />Contains the unit itself in case of collisions. <br />


Passed array: '''[unit, killer]'''


'''Notes:'''
* unit: [[Object]] - Object the event handler is assigned to
* killer: [[Object]] - Object that killed the unit<br>Contains the unit itself in case of collisions.


This command must be used in conjunction with the new command [[addMPEventHandler]] rather than the old command used for non MP commands. This event handler is triggered whenever any player disconnects.
{{Feature|important|
Call a function from the MPKilled EH code space rather than to define the full code in there directly.
The reason is the code space will be transferred over network on each event activation - so keep the data as small as possible!
}}


'''Coding advice:'''
<sqf>
// good
_unit addMPEventHandler ["MPKilled",{_this spawn MyTag_Function;}];


Call a function from the MPKilled EH code space, rather to define the full code in there directly. The reason is the code space will be transferred over network on each event activation - so keep the data as small as possible!
// bad
_unit addMPEventHandler ["MPKilled",{ /* complete script code directly in here */ }];
</sqf>


//good
=== MPRespawn ===
_unit addMPEventHandler ["MPKilled",{_this spawn MyTag_Function;}];
//bad
_unit addMPEventHandler ["MPKilled",{ /* complete script code directly in here */ }];


==MPRespawn==
Triggered when a unit respawns.
Triggered when a unit respawns.


[[Image:arma2oa_1.55.gif]]Global.   [[Image:effects_global.gif|Global effect EventHandler]]
{{GVI|arma2oa|1.55}} Global. {{Icon|globalEffect|32}}


Passed array: '''[unit, corpse, ...]'''
Passed array: '''[unit, corpse, ...]'''
Line 361: Line 453:


'''Notes:'''
'''Notes:'''
As of 1.62, this command does not work as one would expect. It is only triggered on the machine where the unit it was assigned to is local.
The only difference between '''Respawn''' and '''MPRespawn''' is that '''MPRespawn''' can be assigned from anywhere while '''Respawn''' requires the unit to be local.


This command must be used in conjunction with the new command [[addMPEventHandler]] rather than the old command used for non MP commands.
This command must be used in conjunction with the new command [[addMPEventHandler]] rather than the old command used for non MP commands.


[[Category: Event Handlers]]
[[Category: Event Handlers]]
{{GameCategory|arma2|Editing}}

Latest revision as of 16:40, 10 September 2023

An event handler (abbreviated to EH) allows to automatically monitor and then execute custom code upon particular events being triggered.

As opposed to Operation Flashpoint event handlers, in Arma 2 a respawned unit retains the EHs it had before, so it is no longer required to re-add EHs after respawning.


See also: Event Scripts for special event triggered scripts.


Event Handlers List

Related commands:

AnimChanged

Triggered every time a new animation is started.

Global. GEGlobal

Passed array: [unit, anim]

  • unit: Object - Object the event handler is assigned to
  • anim: String - Name of the anim that is given by playMove/switchMove/playAction/switchAction

AnimDone

Triggered every time an animation is finished.

Unknown MP behaviour. Probably local.

Passed array: [unit, anim]

  • unit: Object - Object the event handler is assigned to
  • anim: String - Name of the anim that has been finished

AnimStateChanged

Triggered every time an animation state changes. Unlike AnimChanged and AnimDone, it is triggered for all animation states in a sequence.

Unknown MP behaviour. Probably local.

Passed array: [unit, anim]

  • unit: Object - Object the event handler is assigned to
  • anim: String - Name of the anim that has been started

Dammaged

Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP.

Global. GEGlobal

(If simultaneous damage occurred (e.g. via grenade) EH might be triggered several times.)

Passed array: [unit, selectionName, damage]

  • unit: Object - Object the event handler is assigned to
  • selectionName: String - Name of the selection where the unit was damaged
  • damage: Number - Resulting level of damage

Engine

Triggered when the engine of the unit is turned on/off.

Global. GEGlobal

Passed array: [vehicle, engineState]

  • vehicle: Object - Vehicle the event handler is assigned to
  • engineState: Boolean - True when the engine is turned on, false when turned off

Fired

Triggered when the unit fires a weapon.

This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle.

Global. GEGlobal

Passed array: [unit, weapon, muzzle, mode, ammo]

b1.54.73642 : [unit, weapon, muzzle, mode, ammo, magazine, projectile]

  • unit: Object - Object the event handler is assigned to
  • weapon: String - Fired weapon
  • muzzle: String - Muzzle that was used
  • mode: String - Current mode of the fired weapon
  • ammo: String - Ammo used
  • magazine: String - magazine name which was used
  • projectile: object - Object of the projectile that was shot

FiredNear

Triggered when a weapon is fired somewhere near the unit or vehicle.

It is also triggered if the unit itself is firing.

Global. GEGlobal

Exception: the Throw weapon will not broadcast the FiredNear event.

Passed array: [unit, firer, distance, weapon, muzzle, mode, ammo]

  • unit: Object - Object the event handler is assigned to
  • firer: Object - Object which fires a weapon near the unit
  • distance: Number - Distance in meters between the unit and firer (max. distance ~69m)
  • weapon: String - Fired weapon
  • muzzle: String - Muzzle that was used
  • mode: String - Current mode of the fired weapon
  • ammo: String - Ammo used

Fuel

Triggered when the unit's fuel status changes between completely empty / not empty (only useful if the event handler is assigned to a vehicle).

Global. GEGlobal

Passed array: [vehicle, fuelState]

  • vehicle: Object - Vehicle the event handler is assigned to
  • fuelState: Boolean - 0 when no fuel, 1 when the fuel tank is full

Gear

Triggered when the unit lowers/retracts the landing gear (only useful if the event handler is assigned to is a member of the class "Plane").

Global. GEGlobal Passed array: [vehicle, gearState]

  • vehicle: Object - Vehicle the event handler is assigned to
  • gearState: Boolean - True when the gear is lowered, false when retracted

GetIn

Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands.

Global. GEGlobal

Passed array: [vehicle, position, unit]

  • vehicle: Object - Vehicle the event handler is assigned to
  • position: String - Can be either "driver", "gunner", "commander" or "cargo"
  • unit: Object - Unit that entered the vehicle

GetOut

Triggered when a unit gets out from the object, works the same way as GetIn.

Global. GEGlobal

Passed array: [vehicle, position, unit]

  • vehicle: Object - Vehicle the event handler is assigned to
  • position: String - Can be either "driver", "gunner", "commander" or "cargo"
  • unit: Object - Unit that leaved the vehicle

HandleDamage

Triggered when the unit is damaged. Works with all vehicles.

Code provided must return a value what should be the damage of given part after processing.

Adding this eventhandler with no return value or with return value 0, replaces damage handling by the engine, making the object invulnerable if damage is not scripted in the eventhandler. If you want default processing to be done, be sure to return _this select 2.

You can setDamage and setHit in combination for additional damage handling.

Locality: HandleDamage is triggered where the unit is local. See also Locality in Multiplayer.

Local. LELocal

This EH is triggered separately for every selection of the damaged object.

Passed array: [unit, selectionName, damage, source, projectile]

  • unit: Object - Object the event handler is assigned to.
  • selectionName: String - Name of the selection where the unit was damaged. "" for over-all structural damage, "?" for unknown selections.
  • damage: Number - Resulting level of damage for the selection.
  • source: Object - The source unit that caused the damage.
  • projectile: String - Classname of the projectile that caused inflicted the damage. ("" for unknown, such as falling damage.)


Example:

TargetSoldier addEventHandler ["HandleDamage", { diag_log text format ["T=%1 : %2", time, _this]; _this select 2; }];

When shooting the soldier once in the head, and once in the torso, ArmA2.RPT shows:

T=6.754 : [TargetSoldier,"",0.350463,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"head_hit",3.23586,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"body",0.0743558,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"hands",0.667459,SourceUnit,"B_556x45_Ball"]
T=6.754 : [TargetSoldier,"legs",0.00307311,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"",0.350179,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"head_hit",0.230999,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"body",1.52881,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"hands",0.105206,SourceUnit,"B_556x45_Ball"]
T=10.078 : [TargetSoldier,"legs",0.0211435,SourceUnit,"B_556x45_Ball"]

See Celery's explanation.

Notes:

  • HandleDamage can trigger "twice" per damage event. Once for direct damage, once for indirect damage (explosive damage).
  • This can happen even in the same frame, but is unlikely.
  • Each HandleDamage event show the current damage from the damage source. NOT cumulative or the current "damage level" (health) of the target unit.
  • So a second HandleDamage event can nullify/overwrite the damage of the first event, IF they are in the same frame (or time slice the engine uses the update the damage status of an unit).
  • You can save the last event as timestamp (diag_tickTime) onto the unit, as well as the current health of the unit/it's selections, with setVariable and query it on each HandleDamage event with getVariable to define a system how to handle the new HandleDamage event.
// first HandleDamage event - direct damage by sabot hit onto an infantry unit
1081.55,[TargetUnit,"",6426.05,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"head_hit",441.609,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"body",333.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"hands",533.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"legs",533.333,SourceUnit,"Sh_120_SABOT"]
// second HandleDamage event - indirect damage by the impact - maybe force/friction applied to the unit body
1081.59,[TargetUnit,"",2.24228,TargetUnit,""]
1081.59,[TargetUnit,"head_hit",0.89672,TargetUnit,""]
1081.59,[TargetUnit,"body",3.3113,TargetUnit,""]
1081.59,[TargetUnit,"hands",3.74862,TargetUnit,""]
1081.59,[TargetUnit,"legs",10,TargetUnit,""]

HandleHeal

Triggered when unit starts to heal (player using heal action or AI heals after being ordered). If code returns false, engine side healing follows. Return true if you handle healing in script, use AISFinishHeal to tell engine that script side healing is done. See also lifeState and setUnconscious commands.

Passed array: [unit, healer, healercanheal]

Hit

Triggered when the unit is hit/damaged.

Is not always triggered when unit is killed by a hit.

Most of the time only the killed event handler is triggered when a unit dies from a hit.

The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.

Does not fire when a unit is set to allowDamage false.

Local. LELocal

Passed array: [unit, causedBy, damage]

  • unit: Object - Object the event handler is assigned to
  • causedBy: Object - Object that caused the damage.
    Contains the unit itself in case of collisions.
  • damage: Number - Level of damage caused by the hit

HitPart

WARNING:

As of 2012-02-06, this eventhandler is fundamentally malfunctioning in dedicated multiplayer environments. Make sure you see this ticket before you waste your time with it: -dead link- --Krause 04:53, 7 February 2012 (CET)

Runs when the object, it was added to, gets injured/damaged. It returns the position and component that was hit on the object within a nested array, this is because the model may have more than selection name for the hit component.

A2 OA Logo.png 1.60 Global. GEGlobal

Passed array: [[target, shooter, bullet, position, velocity, selection, ammo, direction, radius, surface, direct]]

  • target: Object - Object that got injured/damaged.
  • shooter: Object - Unit that inflicted the damage. If injured by a vehicle impact or a fall the target itself is returned, or, in case of explosions, the null object. In case of explosives that were planted by someone (e.g. satchel charges), that unit is returned.
  • bullet: Object - Object that was fired.
  • position: Position3D - Position the bullet impacted (ASL).
  • velocity: Vector3D - 3D speed at which bullet impacted.
  • selection: Array - Array of Strings with named selection of the object that were hit.
  • ammo: Array - Ammo info: [hit value, indirect hit value, indirect hit range, explosive damage, ammo class name] OR, if there is no shot object: [impulse value on object collided with,0,0,0]
  • direction: Vector3D - vector that is orthogonal (perpendicular) to the surface struck. For example, if a wall was hit, vector would be pointing out of the wall at a 90 degree angle.
  • radius: Number - Radius (size) of component hit.
  • surface: String - Surface type struck.
  • direct: Boolean - true if object was directly hit, false if it was hit by indirect/splash damage.

IncomingMissile

Triggered when a guided missile locked on the target or unguided missile or rocket aimed by AI at the target was fired.

Global. GEGlobal

Passed array: [unit, ammo, whoFired]

  • unit: Object - Object the event handler is assigned to
  • ammo: String - Ammo type that was fired on the unit
  • whoFired: Object - Object that fired the weapon

Init

Triggered on mission start or when a vehicle is created on the fly using createVehicle.

Global. GEGlobal

Passed array: [unit]

  • unit: Object - Object the event handler is assigned to

Killed

Triggered when the unit is killed.

Local. LELocal

Passed array: [unit, killer]

  • unit: Object - Object the event handler is assigned to
  • killer: Object - Object that killed the unit
    Contains the unit itself in case of collisions.

Be careful when the killer has been a vehicle. For most cases the reference of the vehicle is the same as the effectiveCommander, yet not always. For example:

_gunner setVariable ["Variable",true]; _killer getVariable "Variable"; // <null> (gunner (vehicle _killer)) getVariable "Variable"; // true

And sample debug output:

_killer; // B 1-2-F:2 (gunner (vehicle _killer)); // B 1-2-F:2 (gunner (vehicle _killer)) == _killer; // false

LandedStopped

Triggered when an AI pilot would get out usually. Not executed for player.

Local. LELocal

Passed array: [plane, airportID]

  • plane: Object - Object the event handler is assigned to
  • airportID: Number - ID of the airport (-1 for anything else).

LandedTouchDown

Triggered when a plane (AI or player) touches the ground.

Local. LELocal

Passed array: [plane, airportID]

  • plane: Object - Object the event handler is assigned to
  • airportID: Number - ID of the airport (-1 for anything else).

Respawn

Triggered when a unit respawns.

Passed array: [unit, corpse, ...]

  • unit: Object - Object the event handler is assigned to
  • corpse: Object - Object the event handler was assigned to, aka the corpse/unit player was previously controlling.

WeaponAssembled

Triggers when weapon gets assembled.

A2 OA Logo.png 1.55 Global. GEGlobal

Passed array: [unit, weapon]

  • unit: object - Object the event handler is assigned to
  • weapon: object - Object of the assembled weapon.

WeaponDisassembled

Triggers when weapon gets disassembled.

A2 OA Logo.png 1.55 Global. GEGlobal

Passed array: [unit, primaryBag, secondarybag]

  • unit: object - Object the event handler is assigned to
  • primaryBag: object - First backpack object which was weapon disassembled into...
  • secondarybag: object - Second backpack object which was weapon disassembled into...


Multiplayer Event Handlers List

The new MP event handlers "MPHit", "MPKilled" and "MPRespawn" have to be assigned to the object by using addMPEventHandler.

Related commands:

A Multiplayer Event Handler is not saved in a save file and therefore will not be restored on load - use it accordingly.

MPHit

Triggered when the unit is hit/damaged.

Is not always triggered when unit is killed by a hit.

Most of the time only the killed event handler is triggered when a unit dies from a hit.

The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.

Does not fire when a unit is set to allowDamage false.

A2 OA Logo.png 1.55 Global. GEGlobal

Passed array: [unit, causedBy, damage]

  • unit: Object - Object the event handler is assigned to
  • causedBy: Object - Object that caused the damage.
    Contains the unit itself in case of collisions.
  • damage: Number - Level of damage caused by the hit

MPKilled

Triggered when the unit is killed. This event handler is triggered for a disconnecting player, if "playableAI" are disabled (by admin or Description.ext), so that the playable unit dies on disconnect.

A2 OA Logo.png 1.55 Global. GEGlobal

Passed array: [unit, killer]

  • unit: Object - Object the event handler is assigned to
  • killer: Object - Object that killed the unit
    Contains the unit itself in case of collisions.
Call a function from the MPKilled EH code space rather than to define the full code in there directly. The reason is the code space will be transferred over network on each event activation - so keep the data as small as possible!

// good _unit addMPEventHandler ["MPKilled",{_this spawn MyTag_Function;}]; // bad _unit addMPEventHandler ["MPKilled",{ /* complete script code directly in here */ }];

MPRespawn

Triggered when a unit respawns.

A2 OA Logo.png 1.55 Global. GEGlobal

Passed array: [unit, corpse, ...]

  • unit: Object - Object the event handler is assigned to
  • corpse: Object - Object the event handler was assigned to, aka the corpse/unit player was previously controlling.


Notes:

As of 1.62, this command does not work as one would expect. It is only triggered on the machine where the unit it was assigned to is local. The only difference between Respawn and MPRespawn is that MPRespawn can be assigned from anywhere while Respawn requires the unit to be local.

This command must be used in conjunction with the new command addMPEventHandler rather than the old command used for non MP commands.