Event Handlers – Arma 3

From Bohemia Interactive Community
Category: Event Handlers
No edit summary
m (Adjusted RopeBreak parameter order (courtesy of Ansible2 from Discord, https://discord.com/channels/105462288051380224/105465701543723008/1402841073314693231))
 
(91 intermediate revisions by 14 users not shown)
Line 1: Line 1:
{{TOC|side|0.85}}
{{TOC|side|0.85}}__NOEDITSECTION__
An Event Handler (abbreviated to EH) allows you to automatically monitor and then execute custom code upon particular events being triggered.<br>
An Event Handler (abbreviated to EH) allows you to automatically monitor and then execute custom code upon particular events being triggered.<br>
See also [[Event Scripts]] for special event triggered scripts.
See also [[Event Scripts]] for special event triggered scripts.
Line 6: Line 6:
|title= Main Categories
|title= Main Categories
|content=
|content=
* 1. {{Link|#Basic Event Handlers}}
{{Columns|3|
* 2. {{Link|#Multiplayer Event Handlers}}
# {{Link|#Basic Event Handlers}}
* 3. {{Link|#Mission Event Handlers}}
# {{Link|#Multiplayer Event Handlers}}
* 4. {{Link|#UserAction Event Handlers}}
# {{Link|#Mission Event Handlers}}
* 5. {{Link|#Projectile Event Handlers}}
# {{Link|#Curator Event Handlers}}
* 6. {{Link|#Group Event Handlers}}
# {{Link|#UserAction Event Handlers}}
* 7. {{Link|#Player's UI Event Handlers}}
# {{Link|#Projectile Event Handlers}}
* 8. {{Link|#UI Event Handlers (Displays and Controls)}}
# {{Link|#Group Event Handlers}}
* 9. {{Link|#Music Event Handlers|Music Event Handlers}}
# {{Link|#Game UI Event Handlers}}
* 10. {{Link|#Eden Editor|Eden Editor}}
# {{Link|#Control/Display UI Event Handlers}}
* 11. {{Link|#Public Variable Broadcast Event}}
# {{Link|#Music Event Handlers|Music Event Handlers}}
* 12. {{Link|#Weapon Config Muzzle Events}}
# {{Link|#Eden Editor|Eden Editor}}
* 13. {{Link|#BI Scripted Events}}
# {{Link|#Public Variable Broadcast Event}}
# {{Link|#Weapon Muzzle Config Events}}
# {{Link|#Ammo Config Events}}
# {{Link|#BI Scripted Events}}
}}
}}
}}


Line 24: Line 28:
== Basic Event Handlers ==
== Basic Event Handlers ==


The object-based Event Handler is always executed on the computer where it was added.  
The object-based Event Handler is always executed on the computer where it was added.


Commands:
Commands:
Line 31: Line 35:
* [[removeAllEventHandlers]]
* [[removeAllEventHandlers]]


=== Standard ===
=== AnimChanged ===


{{ConfigPage|start}}
{{ConfigPage|abc}}
==== AnimChanged ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered every time a new animation is started. This EH is only triggered for the 1st animation state in a sequence.
Triggered every time a new animation is started. This EH is only triggered for the 1st animation state in a sequence.
<sqf>
<sqf>
this addEventHandler ["AnimChanged", {
this addEventHandler ["AnimChanged", {
Line 47: Line 49:
* anim: [[String]] - name of the anim that is started
* anim: [[String]] - name of the anim that is started


=== AnimDone ===


==== AnimDone ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered every time an animation is finished. Triggered for all animation states in a sequence.
Triggered every time an animation is finished. Triggered for all animation states in a sequence.
<sqf>
<sqf>
this addEventHandler ["AnimDone", {
this addEventHandler ["AnimDone", {
Line 60: Line 63:
* anim: [[String]] - name of the anim that has been finished
* anim: [[String]] - name of the anim that has been finished


=== AnimStateChanged ===


==== AnimStateChanged ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered every time an animation state changes. Triggered for all animation states in a sequence.
Triggered every time an animation state changes. Triggered for all animation states in a sequence.
<sqf>
<sqf>
this addEventHandler ["AnimStateChanged", {
this addEventHandler ["AnimStateChanged", {
Line 73: Line 77:
* anim: [[String]] - name of the anim that has been started
* anim: [[String]] - name of the anim that has been started


{{ArgTitle|4|CargoLoaded|{{GVI|arma3|2.06}}}}
{{ArgTitle|3|Assembled|{{GVI|arma3|2.18}}}}
 
{{Icon|localArgument|32}}<br>
Triggers when weapon that is moved out of the world is assembled again. EH should be attached to the entity.<br>
 
<sqf>
this addEventHandler ["Assembled", {
params ["_entity", "_unit", "_primaryBag", "_secondaryBag"];
}];
</sqf>
 
* entity: [[Object]] - weapon this event is assigned to
* unit: [[Object]] - person who assembled the weapon
* primaryBag: [[Object]] - first backpack object which was entity disassembled into (just before it is deleted)
* secondaryBag: [[Object]] - second backpack object which was entity disassembled into (just before it is deleted)
 
{{ArgTitle|3|Attached|{{GVI|arma3|2.18}}}}
 
Triggered after an object has been attached to another object (see [[attachTo]]).
 
<sqf>
this addEventHandler ["Attached", {
params ["_attachedObj", "_parentObj", "_isReattach", "_offset", "_memoryPointIndex", "_followBoneRotation"];
}];
</sqf>
 
* attachedObj: [[Object]]
* parentObj: [[Object]]
* isReattach: [[Boolean]] - [[true]] if <var>attachedObj</var> was already attached to <var>parentObj</var>, e.g. if only the offset was changed
* offset: [[Array]] format [[PositionRelative]]
* memoryPointIndex: [[Number]]
* followBoneRotation: [[Boolean]]
 
{{ArgTitle|3|CargoLoaded|{{GVI|arma3|2.06}}}}
 
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a vehicle is loaded into another vehicle ([[setVehicleCargo|ViV]]).<br>
Triggered when a vehicle is loaded into another vehicle ([[setVehicleCargo|ViV]]).<br>
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.
<sqf>
<sqf>
this addEventHandler ["CargoLoaded", {
this addEventHandler ["CargoLoaded", {
Line 86: Line 125:
* cargoVehicle: [[Object]] - the cargo (child) vehicle
* cargoVehicle: [[Object]] - the cargo (child) vehicle


{{ArgTitle|3|CargoUnloaded|{{GVI|arma3|2.06}}}}


{{ArgTitle|4|CargoUnloaded|{{GVI|arma3|2.06}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a vehicle is unloaded from another vehicle ([[setVehicleCargo|ViV]]).<br>
Triggered when a vehicle is unloaded from another vehicle ([[setVehicleCargo|ViV]]).<br>
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.
<sqf>
<sqf>
this addEventHandler ["CargoUnloaded", {
this addEventHandler ["CargoUnloaded", {
Line 100: Line 140:
* cargoVehicle: [[Object]] - the cargo (child) vehicle
* cargoVehicle: [[Object]] - the cargo (child) vehicle


{{ArgTitle|3|ContainerClosed|{{GVI|arma3|1.32}}}}


{{ArgTitle|4|ContainerClosed|{{GVI|arma3|1.32}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when player finished accessing cargo container.
Triggers when player finished accessing cargo container.
This event handler is similar to [[#InventoryClosed|InventoryClosed]] EH, but needs to be assigned to the container rather than the player.
This event handler is similar to [[#InventoryClosed|InventoryClosed]] EH, but needs to be assigned to the container rather than the player.<br>
Note: will trigger only for the unit opening container.
'''Note:''' will trigger only for the unit opening container.


<sqf>
<sqf>
Line 113: Line 153:
</sqf>
</sqf>


* container: [[Object]] - Cargo container.
* container: [[Object]] - cargo container.
* player: [[Object]] - unit who accessed the container
* unit: [[Object]] - unit who accessed the container


{{ArgTitle|3|ContainerOpened|{{GVI|arma3|1.32}}}}


{{ArgTitle|4|ContainerOpened|{{GVI|arma3|1.32}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when cargo container is accessed by player.
Triggers when cargo container is accessed by player.
This event handler is similar to [[#InventoryOpened|InventoryOpened]] EH, but needs to be assigned to the container rather than the player and cannot be overridden.
This event handler is similar to [[#InventoryOpened|InventoryOpened]] EH, but needs to be assigned to the container rather than the player and cannot be overridden.<br>
Note: will trigger only for the unit opening container.
'''Note:''' will trigger only for the unit opening container.


<sqf>
<sqf>
Line 130: Line 170:


* container: [[Object]] - cargo container
* container: [[Object]] - cargo container
* player: [[Object]] - unit who accessed the container
* unit: [[Object]] - unit who accessed the container


{{ArgTitle|3|ControlsShifted|{{GVI|arma3|1.00}}}}


{{ArgTitle|4|ControlsShifted|{{GVI|arma3|1.00}}}}
{{Icon|globalArgument|32}}{{Icon|localEffect|32}}<br>
{{Icon|globalArgument|32}}{{Icon|localEffect|32}}<br>
Triggers when control of a vehicle is shifted (pilot->co-pilot, co-pilot->pilot), usually when user performs an [[action]] such as [[action/Arma_3_Actions_List#TakeVehicleControl | TakeVehicleControl]], [[action/Arma_3_Actions_List#SuspendVehicleControl | SuspendVehicleControl]], [[action/Arma_3_Actions_List#UnlockVehicleControl | UnlockVehicleControl]], [[action/Arma_3_Actions_List#LockVehicleControl | LockVehicleControl]], or when [[enableCopilot]] command is used. This event handler will always fire on the PC where [[action]] is triggered as well as where the vehicle is [[Multiplayer Scripting#Locality|local]] at the time. When control of the vehicle is shifted, the locality of the vehicle changes to the locality of the new controller. For example, if helicopter is [[Multiplayer Scripting#Locality|local]] to the server and co-pilot takes controls, the helicopter changes locality to co-pilot PC.
Triggers when control of a vehicle is shifted (pilot->co-pilot, co-pilot->pilot), usually when user performs an [[action]] such as [[action/Arma_3_Actions_List#TakeVehicleControl | TakeVehicleControl]], [[action/Arma_3_Actions_List#SuspendVehicleControl | SuspendVehicleControl]], [[action/Arma_3_Actions_List#UnlockVehicleControl | UnlockVehicleControl]], [[action/Arma_3_Actions_List#LockVehicleControl | LockVehicleControl]], or when [[enableCopilot]] command is used. This event handler will always fire on the PC where [[action]] is triggered as well as where the vehicle is [[Multiplayer Scripting#Locality|local]] at the time. When control of the vehicle is shifted, the locality of the vehicle changes to the locality of the new controller. For example, if helicopter is [[Multiplayer Scripting#Locality|local]] to the server and co-pilot takes controls, the helicopter changes locality to co-pilot PC.
Line 148: Line 188:
* oldController: [[Object]] - unit who controlled vehicle before this event
* oldController: [[Object]] - unit who controlled vehicle before this event


=== Dammaged ===


==== Dammaged ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP.
Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP.
Line 160: Line 200:
<sqf>
<sqf>
this addEventHandler ["Dammaged", {
this addEventHandler ["Dammaged", {
params ["_unit", "_selection", "_damage", "_hitIndex", "_hitPoint", "_shooter", "_projectile"];
params ["_unit", "_hitSelection", "_damage", "_hitPartIndex", "_hitPoint", "_shooter", "_projectile"];
}];
}];
</sqf>
</sqf>
Line 172: Line 212:
* {{GVI|arma3|1.70}} projectile: [[Object]] - the projectile that caused damage
* {{GVI|arma3|1.70}} projectile: [[Object]] - the projectile that caused damage


{{ArgTitle|3|Deleted|{{GVI|arma3|1.68}}}}


{{ArgTitle|4|Deleted|{{GVI|arma3|1.68}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered just before the assigned entity is deleted.
Triggered just before the assigned entity is deleted.
<sqf>
<sqf>
this addEventHandler ["Deleted", {
this addEventHandler ["Deleted", {
Line 184: Line 225:
* entity: [[Object]] - object the event handler is assigned to
* entity: [[Object]] - object the event handler is assigned to


{{ArgTitle|4|Disassembled|{{GVI|arma3|2.00}}}}
{{ArgTitle|3|Detached|{{GVI|arma3|2.18}}}}
{{Icon|localArgument|32}}<br>
 
Triggers when entity such as weapon/backpack gets disassembled. EH should be attached to the entity.<br>
Triggered after an object has been detached from its parent object (see [[detach]]). Does not fire if the parent object was deleted.
 
<sqf>
<sqf>
this addEventHandler ["Disassembled", {
this addEventHandler ["Detached", {
params ["_entity", "_primaryBag", "_secondaryBag"];
params ["_attachedObj", "_parentObj"];
}];
}];
</sqf>
</sqf>


* entity: [[Object]] - object the event handler is assigned to
* attachedObj: [[Object]]
* parentObj: [[Object]]
 
{{ArgTitle|3|Disassembled|{{GVI|arma3|2.00}}}}
 
{{Icon|localArgument|32}}<br>
Triggers when entity such as weapon/backpack gets disassembled. EH should be attached to the entity.<br>
 
<sqf>
this addEventHandler ["Disassembled", {
params ["_entity", "_primaryBag", "_secondaryBag", "_unit"];
}];
</sqf>
 
* entity: [[Object]] - weapon this event is assigned to (just before is is moved out of the world)
* primaryBag: [[Object]] - first backpack object which was entity disassembled into
* primaryBag: [[Object]] - first backpack object which was entity disassembled into
* secondaryBag: [[Object]] - second backpack object which was entity disassembled into
* secondaryBag: [[Object]] - second backpack object which was entity disassembled into
* {{GVI|arma3|2.18}} unit: [[Object]] - person who disassembled the weapon
=== Engine ===


==== Engine ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the engine of the unit is turned on/off.
Triggered when the engine of the unit is turned on/off.
{{Feature|Informative|Although the event is global, on clients (non-server) and applied to remote vehicles, it will fire only if the vehicle is closer than about 6 km from the camera. Should the vehicle be far away, it will fire as soon as the camera and vehicle are close enough together, alongside the [[isEngineOn]] flag change.}}
{{Feature|informative|
Although the event is global, on clients (non-server) and applied to remote vehicles, it will fire only if the vehicle is closer than about 6 km from the camera.
Should the vehicle be far away, it will fire as soon as the camera and vehicle are close enough together, alongside the [[isEngineOn]] flag change.
}}
 
<sqf>
<sqf>
this addEventHandler ["Engine", {
this addEventHandler ["Engine", {
Line 210: Line 272:
* 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


{{ArgTitle|3|EpeContact|{{GVI|arma3|1.00}}}}


{{ArgTitle|4|EpeContact|{{GVI|arma3|1.00}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when object collision (PhysX) is in progress.
Triggered when object collision (PhysX) is in progress.
<sqf>
<sqf>
this addEventHandler ["EpeContact", {
this addEventHandler ["EpeContact", {
params ["_object1", "_object2", "_selection1", "_selection2", "_force"];
params ["_object1", "_object2", "_selection1", "_selection2", "_force", "_reactVect", "_worldPos"];
}];
}];
</sqf>
</sqf>
Line 222: Line 285:
* object1: [[Object]] - object with attached handler
* object1: [[Object]] - object with attached handler
* object2: [[Object]] - object which is colliding with object1
* object2: [[Object]] - object which is colliding with object1
* select1: [[String]] - selection of object1 which is colliding - not in use at this moment, empty string is always returned
* selection1: [[String]] - selection of object1 which is colliding - not in use at this moment, empty string is always returned
* select2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* selection2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* force: [[Number]] - force of collision
* force: [[Number]] - force of collision
* {{GVI|arma3|2.12}} reactVect: [[Array]] - impact reaction force vector
* {{GVI|arma3|2.12}} worldPos: [[PositionWorld]] - point of impact in world coordinates


{{ArgTitle|3|EpeContactEnd|{{GVI|arma3|1.00}}}}


{{ArgTitle|4|EpeContactEnd|{{GVI|arma3|1.00}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when object collision (PhysX) ends.
Triggered when object collision (PhysX) ends.
<sqf>
<sqf>
this addEventHandler ["EpeContactEnd", {
this addEventHandler ["EpeContactEnd", {
Line 238: Line 304:
* object1: [[Object]] - object with attached handler
* object1: [[Object]] - object with attached handler
* object2: [[Object]] - object which is colliding with object1
* object2: [[Object]] - object which is colliding with object1
* select1: [[String]] - selection of object1 which is colliding - not in use at this moment, empty string is always returned
* selection1: [[String]] - selection of object1 which is colliding - not in use at this moment, empty string is always returned
* select2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* selection2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* force: [[Number]] - force of collision
* force: [[Number]] - force of collision


{{ArgTitle|3|EpeContactStart|{{GVI|arma3|1.00}}}}


{{ArgTitle|4|EpeContactStart|{{GVI|arma3|1.00}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when object collision (PhysX) starts.
Triggered when object collision (PhysX) starts.
<sqf>
<sqf>
this addEventHandler ["EpeContactStart", {
this addEventHandler ["EpeContactStart", {
params ["_object1", "_object2", "_selection1", "_selection2", "_force"];
params ["_object1", "_object2", "_selection1", "_selection2", "_force", "_reactForce", "_worldPos"];
}];
}];
</sqf>
</sqf>
Line 257: Line 324:
* select2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* select2: [[String]] - selection of object2 which is colliding - not in use at this moment, empty string is always returned
* force: [[Number]] - force of collision
* force: [[Number]] - force of collision
* {{GVI|arma3|2.12}} reactForce: [[Array]] - impact reaction force vector
* {{GVI|arma3|2.12}} worldPos: [[PositionWorld]] - point of impact in world coordinates


{{ArgTitle|3|Explosion|{{GVI|arma3|0.76}}}}


{{ArgTitle|4|Explosion|{{GVI|arma3|0.76}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a vehicle or unit is damaged by a nearby explosion.
Triggered when a vehicle or unit is damaged by a nearby explosion.
It can be assigned to a remote unit or vehicle but will only fire on the PC where EH is added and explosion is local, i.e. it really needs to be added on every PC and JIP and will fire only where the explosion is originated.
It can be assigned to a remote unit or vehicle but will only fire on the PC where EH is added and explosion is local, i.e. it really needs to be added on every PC and JIP and will fire only where the explosion is originated.
<sqf>
<sqf>
this addEventHandler ["Explosion", {
this addEventHandler ["Explosion", {
params ["_vehicle", "_damage", "_source"];
params ["_vehicle", "_damage", "_explosionSource"];
}];
}];
</sqf>
</sqf>
Line 271: Line 341:
* vehicle: [[Object]] - object the event handler is assigned to
* vehicle: [[Object]] - object the event handler is assigned to
* damage: [[Number]] - damage inflicted to the object
* damage: [[Number]] - damage inflicted to the object
* {{GVI|arma3|2.10|size= 0.75}} source: [[Object]] - may be [[objNull]] in some cases
* {{GVI|arma3|2.10}} explosionSource: [[Object]] - the exploding object (NOT the shooter) - may be [[objNull]] in some cases


{{Feature|informative|
This event will fire even for tiniest of explosion damage (which appears as 0 damage argument), while {{Link|#HitPart|entity HitPart}} could ignore such damage and not fire.
Example of such event would be a tank firing AP round and hitting ground a meter away from the vehicle, it does not produce an explosion yet its {{Link|CfgAmmo Config Reference#indirectHit|indirectHit}} could still cause tiny amount of damage to weak hit points (car wheels, headlights, etc.).
In such case you might not get any {{Link|#HitPart}} event fires, get some {{Link|#HandleDamage}} events if target is local, and get this Explosion event.}}
=== Fired ===


==== Fired ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the unit fires a weapon.<br>
Triggered when the unit fires a weapon.<br>
Line 280: Line 355:
When "Manual Fire" is used, the ''gunner'' is [[objNull]] if gunner is not present or the ''gunner'' is not the one who fires.
When "Manual Fire" is used, the ''gunner'' is [[objNull]] if gunner is not present or the ''gunner'' is not the one who fires.
To check if "Manual Fire" is on, use [[isManualFire]]. The actual shot instigator could be retrieved with [[getShotParents]] command.<br>
To check if "Manual Fire" is on, use [[isManualFire]]. The actual shot instigator could be retrieved with [[getShotParents]] command.<br>
{{Feature|Warning|'''Special multiplayer behaviour:''' When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera. That range is determined by the fired ammo's highest visibleFire and audibleFire config value. In case of units, muzzle attachment coefficients are applied too.}}
{{Feature|warning|
'''Special multiplayer behaviour:''' When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera.
That range is determined by the fired ammo's highest visibleFire and audibleFire config value.
In case of units, muzzle attachment coefficients are applied too.
}}


<sqf>
<sqf>
Line 297: Line 376:
* {{GVI|arma3|1.66}} gunner: [[Object]] - gunner whose weapons are firing.
* {{GVI|arma3|1.66}} gunner: [[Object]] - gunner whose weapons are firing.


{{ArgTitle|3|FiredMan|{{GVI|arma3|1.66}}}}


{{ArgTitle|4|FiredMan|{{GVI|arma3|1.66}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the unit fires a weapon. This EH must be attached to a soldier and unlike with "Fired" EH, it will fire regardless of whether the soldier is on foot or firing vehicle weapon.
Triggered when the unit fires a weapon. This EH must be attached to a soldier and unlike with "Fired" EH, it will fire regardless of whether the soldier is on foot or firing vehicle weapon.
For [[remoteControl]]ed unit use "Fired" EH instead.
For [[remoteControl]]ed unit use "Fired" EH instead.
{{Feature|Warning|'''Special multiplayer behaviour:''' When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera. That range is determined by the fired ammo's highest visibleFire and audibleFire config value. In case of units, muzzle attachment coefficients are applied too.}}
{{Feature|warning|
'''Special multiplayer behaviour:''' When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera.
That range is determined by the fired ammo's highest visibleFire and audibleFire config value.
In case of units, muzzle attachment coefficients are applied too.
}}
 
<sqf>
<sqf>
this addEventHandler ["FiredMan", {
this addEventHandler ["FiredMan", {
Line 318: Line 402:
* vehicle: [[Object]] - vehicle, if weapon is vehicle weapon, otherwise [[objNull]]
* vehicle: [[Object]] - vehicle, if weapon is vehicle weapon, otherwise [[objNull]]


=== FiredNear ===


==== FiredNear ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a weapon is fired somewhere ''near'' the unit or vehicle. It is also triggered if the unit itself is firing.
Triggered when a weapon is fired somewhere ''near'' the unit or vehicle. It is also triggered if the unit itself is firing.<br>
(Exception(s): the Throw weapon wont broadcast the FiredNear event).
When "Manual Fire" is used, the ''gunner'' is [[objNull]] if gunner is not present or the ''gunner'' is not the one who fires.
When "Manual Fire" is used, the ''gunner'' is [[objNull]] if gunner is not present or the ''gunner'' is not the one who fires.
To check if "Manual Fire" is on, use [[isManualFire]]. The actual shot instigator could be retrieved with [[getShotParents]] command.
To check if "Manual Fire" is on, use [[isManualFire]]. The actual shot instigator can be retrieved with [[getShotParents]] command.<br>
{{GVI|arma3|1.30}} Works with thrown weapons.
{{GVI|arma3|1.30}} Works with thrown weapons (using the "Throw" weapon) like grenades.
 
<sqf>
<sqf>
this addEventHandler ["FiredNear", {
this addEventHandler ["FiredNear", {
Line 341: Line 425:
* {{GVI|arma3|1.66}} gunner: [[Object]] - gunner, whose weapons are fired
* {{GVI|arma3|1.66}} gunner: [[Object]] - gunner, whose weapons are fired


=== Fuel ===


==== Fuel ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the vehicle's fuel status changes between non-empty and empty or between empty and non-empty.
Triggered when the vehicle's fuel status changes between non-empty and empty or between empty and non-empty.
<sqf>
<sqf>
this addEventHandler ["Fuel", {
this addEventHandler ["Fuel", {
Line 354: Line 439:
* hasFuel: [[Boolean]] - false when has no fuel, true when has some fuel
* hasFuel: [[Boolean]] - false when has no fuel, true when has some fuel


=== Gear ===


==== Gear ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the unit lowers/retracts the landing gear, whether it is a helicopter or a plane.
Triggered when the unit lowers/retracts the landing gear, whether it is a helicopter or a plane.
Also triggered for helicopters in landing mode, regardless if they have retractable gear or not.
Also triggered for helicopters in landing mode, regardless if they have retractable gear or not.
{{Feature|Informative|Not to be confused with ''[[Arma 3: Event Handlers#InventoryOpened|InventoryOpened]]'' and ''[[Arma 3: Event Handlers#InventoryClosed|InventoryClosed]]'' events, ''Gear'' fires when the landing gear state on an aircraft has changed.}}
{{Feature|informative|
Not to be confused with ''[[Arma 3: Event Handlers#InventoryOpened|InventoryOpened]]'' and ''[[Arma 3: Event Handlers#InventoryClosed|InventoryClosed]]'' events, ''Gear'' fires when the landing gear state on an aircraft has changed.
}}
 
<sqf>
<sqf>
this addEventHandler ["Gear", {
this addEventHandler ["Gear", {
Line 369: Line 457:
* gearState: [[Boolean]] - true when the gear is lowered, false when retracted
* gearState: [[Boolean]] - true when the gear is lowered, false when retracted


{{ArgTitle|3|GestureChanged|{{GVI|arma3|2.06}}}}


{{ArgTitle|4|GestureChanged|{{GVI|arma3|2.06}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered every time a new gesture is played.
Triggered every time a new gesture is played.
<sqf>
<sqf>
this addEventHandler ["GestureChanged", {
this addEventHandler ["GestureChanged", {
Line 382: Line 471:
* gesture: [[String]] - name of the gesture that has started playing
* gesture: [[String]] - name of the gesture that has started playing


{{ArgTitle|3|GestureDone|{{GVI|arma3|2.06}}}}


{{ArgTitle|4|GestureDone|{{GVI|arma3|2.06}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered every time a gesture is finished.
Triggered every time a gesture is finished.
<sqf>
<sqf>
this addEventHandler ["GestureDone", {
this addEventHandler ["GestureDone", {
Line 395: Line 485:
* gesture: [[String]] - name of the gesture that has been finished
* gesture: [[String]] - name of the gesture that has been finished


=== GetIn ===


==== GetIn ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when a unit enters the vehicle to which this EH has been added. This EH is triggered by moveInXXXX commands and "GetInXXXX" [[action]]s, but not upon a seat change within the same vehicle.
Triggers when a unit enters the vehicle to which this EH has been added. This EH is triggered by moveInXXXX commands and "GetInXXXX" [[action]]s, but not upon a seat change within the same vehicle.


In vehicles with multi-turret setup, entering any turret will show "gunner" for position.
In vehicles with multi-turret setup, entering any turret will show "gunner" for position.
<sqf>
<sqf>
this addEventHandler ["GetIn", {
this addEventHandler ["GetIn", {
Line 408: Line 499:


* vehicle: [[Object]] - vehicle the event handler is assigned to
* vehicle: [[Object]] - vehicle the event handler is assigned to
* role: [[String]] - can be either "driver", "gunner" or "cargo"
* role: [[String]] - can be either "driver", "gunner", "commander" or "cargo"
* unit: [[Object]] - unit that entered the vehicle
* unit: [[Object]] - unit that entered the vehicle
* {{GVI|arma3|1.36}} turret: [[Array]] - turret path
* {{GVI|arma3|1.36}} turret: [[Array]] - turret path


{{ArgTitle|3|GetInMan|{{GVI|arma3|1.58}}}}


{{ArgTitle|4|GetInMan|{{GVI|arma3|1.58}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when a unit enters a vehicle. Similar to "GetIn" but must be assigned to a unit and not vehicle.
Triggers when a unit enters a vehicle. Similar to "GetIn" but must be assigned to a unit and not vehicle.
Persistent on respawn if assigned where unit was [[Multiplayer Scripting#Locality|local]]. This EH is triggered by moveInXXXX commands and "GetInXXXX" [[action]]s.
Persistent on respawn if assigned where unit was [[Multiplayer Scripting#Locality|local]]. This EH is triggered by moveInXXXX commands and "GetInXXXX" [[action]]s.
<sqf>
<sqf>
this addEventHandler ["GetInMan", {
this addEventHandler ["GetInMan", {
Line 424: Line 516:


* unit: [[Object]] - unit the event handler is assigned to
* unit: [[Object]] - unit the event handler is assigned to
* role: [[String]] - can be either "driver", "gunner" or "cargo"
* role: [[String]] - can be either "driver", "gunner", "commander" or "cargo"
* vehicle: [[Object]] - vehicle the unit entered
* vehicle: [[Object]] - vehicle the unit entered
* turret: [[Array]] - turret path
* turret: [[Array]] - turret path


=== GetOut ===


==== GetOut ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when a unit gets out from the vehicle to which this EH has been added.
Triggers when a unit gets out from the vehicle to which this EH has been added.
This EH is triggered by [[moveOut]], "GetOut" & "Eject" [[action]]s, if an [[alive]] [[crew]] member disconnects or is deleted, but not upon a seat change within the same vehicle.
This EH is triggered by [[moveOut]], "GetOut" & "Eject" [[action]]s, if an [[alive]] [[crew]] member disconnects or is deleted, but not upon a seat change within the same vehicle.
<sqf>
<sqf>
this addEventHandler ["GetOut", {
this addEventHandler ["GetOut", {
params ["_vehicle", "_role", "_unit", "_turret"];
params ["_vehicle", "_role", "_unit", "_turret", "_isEject"];
}];
}];
</sqf>
</sqf>


* vehicle: [[Object]] - vehicle the event handler is assigned to
* vehicle: [[Object]] - vehicle the event handler is assigned to
* role: [[String]] - can be either "driver", "gunner" or "cargo"
* role: [[String]] - can be either "driver", "gunner", "commander" or "cargo"
* unit: [[Object]] - unit that left the vehicle
* unit: [[Object]] - unit that left the vehicle
* {{GVI|arma3|1.36}} turret: [[Array]] - turret path
* {{GVI|arma3|1.36}} turret: [[Array]] - turret path
* {{GVI|arma3|2.14}} isEject: [[Boolean]] - [[true]] if unit used 'Eject' action


{{ArgTitle|3|GetOutMan|{{GVI|arma3|1.58}}}}


{{ArgTitle|4|GetOutMan|{{GVI|arma3|1.58}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when a unit exits a vehicle. Similar to "GetOut" but must be assigned to a unit and not vehicle.
Triggers when a unit exits a vehicle. Similar to "GetOut" but must be assigned to a unit and not vehicle.
Persistent on respawn if assigned where unit was [[Multiplayer Scripting#Locality|local]]. This EH is triggered by [[moveOut]] and "GetOut" & "Eject" [[action]]s.
Persistent on respawn if assigned where unit was [[Multiplayer Scripting#Locality|local]]. This EH is triggered by [[moveOut]] and "GetOut" & "Eject" [[action]]s.
<sqf>
<sqf>
this addEventHandler ["GetOutMan", {
this addEventHandler ["GetOutMan", {
params ["_unit", "_role", "_vehicle", "_turret"];
params ["_unit", "_role", "_vehicle", "_turret", "_isEject"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - unit the event handler is assigned to
* unit: [[Object]] - unit the event handler is assigned to
* role: [[String]] - can be either "driver", "gunner" or "cargo"
* role: [[String]] - can be either "driver", "gunner", "commander" or "cargo"
* vehicle: [[Object]] - vehicle that the unit left
* vehicle: [[Object]] - vehicle that the unit left
* turret: [[Array]] - turret path
* turret: [[Array]] - turret path
* {{GVI|arma3|2.14}} isEject: [[Boolean]] - [[true]] if unit used 'Eject' action


=== HandleDamage ===


==== HandleDamage ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when the unit is damaged and fires for each damaged selection separately  
Triggers when the unit is damaged and fires for each damaged selection separately
Note: Currently, in Arma 3 v1.70 it triggers for every selection of a vehicle, no matter if the section was damaged or not). Works with all vehicles.
Works with all vehicles.
This EH can accept a remote unit as argument however it will only fire when the unit is [[Multiplayer Scripting#Locality|local]] to the PC this event handler was added on.
This EH can accept a remote unit as argument however it will only fire when the unit is [[Multiplayer Scripting#Locality|local]] to the PC this event handler was added on.
For example, you can add this event handler to one particular vehicle on every PC.
For example, you can add this event handler to one particular vehicle on every PC.
When this vehicle gets hit, only EH on PC where the vehicle is currently [[Multiplayer Scripting#Locality|local]] will fire.
When this vehicle gets hit, only EH on PC where the vehicle is currently [[Multiplayer Scripting#Locality|local]] will fire.


If code provided returns a numeric value, this value will overwrite the default damage of given selection after processing.
If the provided code returns a numeric value, this value will overwrite the default damage of given selection after processing.
Return value of 0 will make the unit invulnerable if damage is not scripted in other ways (i.e using [[setDamage]] and/or [[setHit]] for additional damage handling).
If no value is returned, the default damage processing will be done - this allows for safe stacking of this event handler.
If no value is returned, the default damage processing will be done. This allows for safe stacking of this event handler.
Only the return value of the last added "HandleDamage" EH is considered.
Only the return value of the last added "HandleDamage" EH is considered.
{{Feature|important|
A return value of 0 will make the unit '''invulnerable''' if damage is not scripted in other ways (i.e using [[setDamage]] and/or [[setHit]] for additional damage handling).
The return value is the hit zone's '''absolute damage value''', '''not''' the damage to be ''added'' to it.
}}


'''Notes:'''
'''Notes:'''
* Multiple "HandleDamage" event handlers can be added to the same unit. If multiple EHs return damage value for custom damage handling, only last returned value will be considered by the engine.
* Multiple "HandleDamage" EHs can be added to the same unit. If multiple EHs return damage value for custom damage handling, only last returned value will be considered by the engine.
EHs that do not return value can be safely added after EHs that do return value.
EHs that do not return value can be safely added after EHs that do return value.
* You can save the last event as timestamp ([[diag_tickTime]]) onto the unit, as well as the current health of the unit/its selections, with [[setVariable]] and query it on each "HandleDamage" event with [[getVariable]] to define a system how to handle the "HandleDamage" event.
* You can save the last event as timestamp ([[diag_tickTime]]) onto the unit, as well as the current health of the unit/its selections, with [[setVariable]] and query it on each "HandleDamage" event with [[getVariable]] to define a system how to handle the "HandleDamage" event.
Line 481: Line 580:
* "HandleDamage" is persistent. If you add it to the [[player]] object, it will continue to exist after player respawned.
* "HandleDamage" is persistent. If you add it to the [[player]] object, it will continue to exist after player respawned.
* "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.
* "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.
* Use [[setMissionOptions]] to filter out no damage calls or fake head hit.


Additional {{Link|https://forums.bistudio.com/forums/topic/205515-handledamage-event-handler-explained/|Celery's explanation (Updated by ShadowRanger for {{arma3}})}}.
Additional {{Link|https://forums.bistudio.com/forums/topic/205515-handledamage-event-handler-explained/|Celery's explanation (Updated by ShadowRanger for {{arma3}})}}.
Line 486: Line 586:
<sqf>
<sqf>
this addEventHandler ["HandleDamage", {
this addEventHandler ["HandleDamage", {
params ["_unit", "_selection", "_damage", "_source", "_projectile", "_hitIndex", "_instigator", "_hitPoint"];
params ["_unit", "_selection", "_damage", "_source", "_projectile", "_hitPartIndex", "_instigator", "_hitPoint", "_directHit", "_context"];
}];
}];
</sqf>
</sqf>
Line 496: Line 596:
* damage: [[Number]] - resulting level of damage for the selection
* damage: [[Number]] - resulting level of damage for the selection
* source: [[Object]] - the source unit that caused the damage
* 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)
* projectile: [[String]] - classname of the projectile that caused inflicted the damage. ("" for unknown, such as fall damage)
* {{GVI|arma3|1.50}} hitPartIndex: [[Number]] - hit part index of the hit point, -1 otherwise
* {{GVI|arma3|1.50}} hitPartIndex: [[Number]] - hit part index of the hit point, -1 otherwise
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.68}} hitPoint: [[String]] - hit point Cfg name
* {{GVI|arma3|1.68}} hitPoint: [[String]] - hit point Cfg name
* {{GVI|arma3|2.12}} directHit: [[Boolean]] - [[true]] for direct projectile damage, [[false]] for explosion splash damage and all other kinds of damage like fall damage, fire damage, collision damage, etc.
* {{GVI|arma3|2.16}} context: [[Number]] - some additional context for the event:
<br>0 : TotalDamage - total damage adjusted before iteration through hitpoints
<br>1 : HitPoint - some hit point processed during iteration
<br>2 : LastHitPoint - the last hitpoint from iteration is processed
<br>3 : FakeHeadHit - head hit that is added/adjusted
<br>4 : TotalDamageBeforeBleeding - total damage is adjusted before calculating bleeding
{{Feature|informative|Between an unknown version (confirmed in {{arma3}} v1.70) until v1.78 HandleDamage event triggered for every selection of a vehicle, no matter if the section was damaged or not.}}


=== HandleHeal ===


==== HandleHeal ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when unit starts to heal (player using heal action or AI heals after being ordered).
Triggered when unit starts healing process (player using heal action on self or other unit, scripted [[action]] or AI heals after being ordered or on its own).
Triggers only on PC where EH is added and unit is [[Multiplayer Scripting#Locality|local]].
This event handler must be added to the 'injured' (could be added to Init field in editor) and in multiplayer will trigger only on PC where 'healer' is [[Multiplayer Scripting#Locality|local]]. If code returns anything but [[true]], engine side healing follows, otherwise healing is aborted.
If code returns false, engine side healing follows.
{{Feature|important|When AI unit is ordered (or acts at own accord) to heal at a medical vehicle and the event handler returns [[true]], the healing is canceled but AI will try again and again and again. The event handler in this case will fire every second until AI unit is healed by other means.}}
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.<br><br>
'''NOTE''': This Event Handler was broken before {{arma3}} v2.18.
'''NOTE''': This Event Handler is broken but somewhat usable.
 
When attached to a unit it will fire when medic action is started (not finished!) on the unit.
<sqf inline>_this select 0</sqf> will be the unit itself, <sqf inline>_this select 1</sqf> will be the healer.
The 3rd param will always be [[false]] and neither returning [[true]] nor using [[AISFinishHeal]] will have any effect on the engine default healing behaviour.
If unit walks away from the healer during healing action, the heal will not finish but there is no way to detect this within "HandleHeal" framework.<br><br>
This code will fix unit to 100% health after self-use of medpack:
<sqf>
<sqf>
this addEventHandler ["HandleHeal", {
this addEventHandler ["HandleHeal", {
_this spawn {
_this spawn {
params ["_injured", "_healer"];
params ["_injured", "_healer", "_isMedic", "_atVehicle", "_action"];
private _damage = damage _injured;
private _damage = damage _injured;
if (_injured == _healer) then {
if (_injured == _healer) then
{
waitUntil { damage _injured != _damage };
waitUntil { damage _injured != _damage };
if (damage _injured < _damage) then {
if (damage _injured < _damage) then
{
_injured setDamage 0;
_injured setDamage 0;
};
};
Line 529: Line 635:
}];
}];
</sqf>
</sqf>
<sqf>
<sqf>
this addEventHandler ["HandleHeal", {
this addEventHandler ["HandleHeal", {
params ["_unit", "_healer", "_isMedic"];
params ["_injured", "_healer", "_isMedic", "_atVehicle", "_action"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]]
* injured: [[Object]] - unit EH is attached to
* healer: [[Object]]
* healer: [[Object]] - unit that does the healing (could be the same unit as 'injured')
* isMedic: [[Boolean]] - true when healer is corpsman
* isMedic: [[Boolean]] - true when healer is 'Medic'
* {{GVI|arma3|2.18}} atVehicle: [[Object]] - when healing at medical vehicle, this is the vehicle
* {{GVI|arma3|2.18}} action: [[String]] - the action that triggered the event handler, for example "SoldierHealSelf"


=== HandleIdentity ===


==== HandleIdentity ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered whenever an entity is created. Can be used in scripts if EH is added immediately after unit is created in [[Scheduler#Unscheduled_Environment|unscheduled environment]].
Triggered whenever an entity is created. Can be used in scripts if EH is added immediately after unit is created in [[Scheduler#Unscheduled Environment|unscheduled environment]].
Doesn't trigger for editor placed units. Does not work in Multiplayer. If EH scope returns [[true]], the default engine identity application is overridden.
Doesn't trigger for editor placed units. Does not work in Multiplayer. If EH scope returns [[true]], the default engine identity application is overridden.
<sqf>
<sqf>
bob = group player createUnit [typeOf player, position player, [], 0, "none"];
bob = group player createUnit [typeOf player, position player, [], 0, "NONE"];
bob addEventHandler ["HandleIdentity", { hint str _this }];
bob addEventHandler ["HandleIdentity", {
params ["_unit"];
hint str _unit;
}];
</sqf>
</sqf>
* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - object the event handler is assigned to


{{ArgTitle|3|HandleRating|{{GVI|arma3|1.32}}}}


{{ArgTitle|4|HandleRating|{{GVI|arma3|1.32}}}}
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when engine adds rating to overall rating of the unit, usually after a kill or a friendly kill.
Triggered when engine adds rating to overall rating of the unit, usually after a kill or a friendly kill.
If EH code returns [[Number]], this will override default engine behaviour and the resulting value added will be the one returned by EH code.
If EH code returns [[Number]], this will override default engine behaviour and the resulting value added will be the one returned by EH code.
<sqf>
<sqf>
this addEventHandler ["HandleRating", {
this addEventHandler ["HandleRating", {
Line 564: Line 679:
* rating: [[Number]] - rating to be added
* rating: [[Number]] - rating to be added


{{ArgTitle|3|HandleScore|{{GVI|arma3|1.32}}}}


{{ArgTitle|4|HandleScore|{{GVI|arma3|1.32}}}}
{{Icon|globalArgument|32}}{{Icon|serverExec|32}}<br>
{{Icon|globalArgument|32}}{{Icon|serverExec|32}}<br>
Triggered when engine adds score to overall score of the unit, usually after a kill.
Triggered when engine adds score to overall score of the unit, usually after a kill.
If the EH code returns [[Nothing]] or [[true]], the default engine scoreboard update (score, vehicle kills, infantry kills, etc) is applied, if it returns [[false]], the engine update is cancelled. To add or modify score, use [[addScore]] and [[addScoreSide]] commands.
If the EH code returns [[Nothing]] or [[true]], the default engine scoreboard update (score, vehicle kills, infantry kills, etc) is applied, if it returns [[false]], the engine update is cancelled. To add or modify score, use [[addScore]] and [[addScoreSide]] commands.
For remote units like players, the event does not persist after respawn, and must be re-added to the new unit. <br><br>
For remote units like players, the event does not persist after respawn, and must be re-added to the new unit.<br>
'''NOTE:''' MP only.
'''Note:''' MP only.
 
<sqf>
<sqf>
this addEventHandler ["HandleScore", {
this addEventHandler ["HandleScore", {
Line 581: Line 697:
* score: [[Number]] - score to be added
* score: [[Number]] - score to be added


=== Hit ===


==== Hit ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
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.<br>
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>
Most of the time only the [[#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>
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.
Does not fire when a unit is set to allowDamage false.
<sqf>
<sqf>
this addEventHandler ["Hit", {
this addEventHandler ["Hit", {
Line 601: Line 718:
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger


=== HitPart ===


==== HitPart ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Runs when the object it was added to gets injured/damaged.
Runs when the object it was added to gets injured/damaged.
Line 617: Line 734:
<sqf>
<sqf>
this addEventHandler ["HitPart", {
this addEventHandler ["HitPart", {
(_this select 0) params ["_target", "_shooter", "_projectile", "_position", "_velocity", "_selection", "_ammo", "_vector", "_radius", "_surfaceType", "_isDirect"];
(_this select 0) params ["_target", "_shooter", "_projectile", "_position", "_velocity", "_selection", "_ammo", "_vector", "_radius", "_surfaceType", "_isDirect", "_instigator"];
}];
}];
</sqf>
</sqf>
Line 627: Line 744:
* position: [[Array]] format [[Position#PositionASL|PositionASL]] - position the bullet impacted
* position: [[Array]] format [[Position#PositionASL|PositionASL]] - position the bullet impacted
* velocity: [[Vector3D]] - 3D speed at which the bullet impacted
* velocity: [[Vector3D]] - 3D speed at which the bullet impacted
* selection: [[Array]] - array of [[String]]s with named selection of the object that were hit
* selection: [[Array]] - array of [[String]]s with named selection of the object that were hit, in the FireGeometry LOD.
* ammo: [[Array]] - ammo info: [hit value, indirect hit value, indirect hit range, explosive damage, ammo class name]; Or, in case of a vehicle collision: [impulse value, 0, 0, 0]; hit and damage values are derived from the projectile's [[CfgAmmo Config Reference|CfgAmmo]] class, and do not match the actual damage inflicted, which is usually lower due to armor and other factors
* ammo: [[Array]] - ammo info: [hit value, indirect hit value, indirect hit range, explosive damage, ammo class name]; Or, in case of a vehicle collision: [impulse value, 0, 0, 0]; hit and damage values are derived from the projectile's [[CfgAmmo Config Reference|CfgAmmo]] class, and do not match the actual damage inflicted, which is usually lower due to armor and other factors
* vector: [[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
* vector: [[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
* radius: [[Number]] - radius (size) of component hit
* surface: [[String]] - surface type struck
* surfaceType: [[String]] - surface type struck
* direct: [[Boolean]] - [[true]] if object was directly hit, [[false]] if it was hit by indirect/splash damage
* isDirect: [[Boolean]] - [[true]] if object was directly hit, [[false]] if it was hit by indirect/splash damage
* {{GVI|arma3|2.18}} instigator: [[Object]] - shot instigator


{{Feature|informative|There is similar event handler that is attached to [[#HitPart_2|projectile]] instead of entity.}}
{{Feature|informative|This event doesn't fire when miniscule explosive damage is dealt to target entity, but [[#Explosion|Explosion]] event will still fire.}}


==== Init ====
=== IncomingMissile ===
{{Icon|globalArgument|32}}<br>
Triggered whenever an entity is created. Cannot be used in scripts, only inside class Eventhandlers in config.
e.g:
<syntaxhighlight lang="cpp">init = "params ['_entity'];";</syntaxhighlight>
<sqf>params ["_entity"];</sqf>
* entity: [[Object]] - object the event handler is assigned to


==== IncomingMissile ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a unit fires a missile or rocket at the target. For projectiles fired by players this EH only triggers for guided missiles that have locked onto the target.
Triggered when a unit fires a missile or rocket at the target. For projectiles fired by players this EH only triggers for guided missiles that have locked onto the target.
<sqf>
<sqf>
this addEventHandler ["IncomingMissile", {
this addEventHandler ["IncomingMissile", {
Line 659: Line 772:
* {{GVI|arma3|2.10}} missile: [[Object]] - the incoming missile
* {{GVI|arma3|2.10}} missile: [[Object]] - the incoming missile


=== Init ===


{{ArgTitle|4|InventoryClosed|{{GVI|arma3|1.22}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when the unit closes inventory. Said unit can be non-local when adding the EH, but '''must''' be local for the EH to trigger.
Triggered whenever an entity is created. Cannot be used in scripts, only inside class Eventhandlers in config.
{{Feature|important|It is recommended to use the {{Link|#PostInit}} event handler instead of this one when setting entity textures ([[setObjectTexture]], [[BIS_fnc_initVehicle]] etc) to avoid networking issues.}}
 
e.g:
<syntaxhighlight lang="cpp">init = "params ['_entity'];";</syntaxhighlight>
<sqf>params ["_entity"];</sqf>
 
* entity: [[Object]] - object the event handler is assigned to
 
{{ArgTitle|3|InventoryClosed|{{GVI|arma3|1.22}}}}
 
{{Icon|globalArgument|32}}<br>
Triggered when the unit closes inventory. Said unit can be non-local when adding the EH, but '''must''' be local for the EH to trigger.
 
<sqf>
<sqf>
this addEventHandler ["InventoryClosed", {
this addEventHandler ["InventoryClosed", {
Line 670: Line 796:


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - object the event handler is assigned to
* targetContainer: [[Object]] - connected container or weaponholder
* container: [[Object]] - connected container or weaponholder
 
<sqf>
<sqf>
// Delete dropped items when inventory closed
// Delete dropped items when inventory closed
Line 682: Line 809:
</sqf>
</sqf>


{{ArgTitle|3|InventoryOpened|{{GVI|arma3|1.22}}}}


{{ArgTitle|4|InventoryOpened|{{GVI|arma3|1.22}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when unit opens inventory. Said unit can be non-local when adding the EH, but '''must''' be local for the EH to trigger. End EH main scope with [[true]] to override the opening of the inventory in case you wish to handle it yourself:
Triggered when unit opens inventory. Said unit can be non-local when adding the EH, but '''must''' be local for the EH to trigger. End EH main scope with [[true]] to override the opening of the inventory in case you wish to handle it yourself:
Line 697: Line 824:
}];
}];
</sqf>
</sqf>
To return all nearby containers use [[nearSupplies]] command.
To return all nearby containers use [[nearSupplies]] command.
<sqf>
<sqf>
this addEventHandler ["InventoryOpened", {
this addEventHandler ["InventoryOpened", {
params ["_unit", "_container"];
params ["_unit", "_primaryContainer", "_secondaryContainer"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - object the event handler is assigned to
* targetContainer: [[Object]] - connected container or weaponholder
* primaryContainer: [[Object]] - connected container or weaponholder
* {{GVI|arma3|1.66}} secondaryContainer: [[Object]] - second connected container or weaponholder or [[objNull]]
* {{GVI|arma3|1.66}} secondaryContainer: [[Object]] - second connected container or weaponholder or [[objNull]]


=== Killed ===


==== Killed ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when the unit is killed.
Triggered when the unit is killed.


Be careful when the killer has been a vehicle. For most cases the reference of the vehicle is the same as the [[effectiveCommander]], but not always.
<sqf>
<sqf>
this addEventHandler ["Killed", {
this addEventHandler ["Killed", {
Line 720: Line 848:
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - the object the event handler is assigned to
* killer: [[Object]] - object that killed the unit. Contains the unit itself in case of collisions
* killer: [[Object]] - the object that killed the unit. Contains the unit itself in case of collisions.
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.66}} instigator: [[Object]] - the person who pulled the trigger
* {{GVI|arma3|1.68}} useEffects: [[Boolean]] - same as ''useEffects'' in [[setDamage]] alt syntax
* {{GVI|arma3|1.68}} useEffects: [[Boolean]] - same as ''useEffects'' in [[setDamage]] alt syntax


=== LandedStopped ===


==== LandedTouchDown ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when a plane (AI or player) touches the ground.
Triggered when an AI pilot would get out usually. Not executed for player.
 
<sqf>
<sqf>
this addEventHandler ["LandedTouchDown", {
this addEventHandler ["LandedStopped", {
params ["_plane", "_airportID"];
params ["_plane", "_airportID", "_airportObject"];
}];
}];
</sqf>
</sqf>
Line 737: Line 866:
* plane: [[Object]] - object the event handler is assigned to
* plane: [[Object]] - object the event handler is assigned to
* airportID: [[Number]] - ID of the airport (-1 for anything else)
* airportID: [[Number]] - ID of the airport (-1 for anything else)
* {{GVI|arma3|2.12}} airportObject: [[Object]] - airport object in the event of a [[Arma 3: Dynamic Airport Configuration|Dynamic Airport]], otherwise [[objNull]]


=== LandedTouchDown ===


==== LandedStopped ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when an AI pilot would get out usually. Not executed for player.
Triggered when a plane (AI or player) touches the ground.
 
<sqf>
<sqf>
this addEventHandler ["LandedStopped", {
this addEventHandler ["LandedTouchDown", {
params ["_plane", "_airportID"];
params ["_plane", "_airportID", "_airportObject"];
}];
}];
</sqf>
</sqf>
Line 750: Line 881:
* plane: [[Object]] - object the event handler is assigned to
* plane: [[Object]] - object the event handler is assigned to
* airportID: [[Number]] - ID of the airport (-1 for anything else)
* airportID: [[Number]] - ID of the airport (-1 for anything else)
* {{GVI|arma3|2.12}} airportObject: [[Object]] - airport object in the event of a [[Arma 3: Dynamic Airport Configuration|Dynamic Airport]], otherwise [[objNull]]


{{ArgTitle|3|Landing|{{GVI|arma3|1.70}}}}


{{ArgTitle|4|Landing|{{GVI|arma3|1.70}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when an AI pilot (or auto-pilot) is preparing for landing. The exact moment of triggering coincides with lowering of the gear ("Gear" EH)
Triggered when an AI pilot (or auto-pilot) is preparing for landing. The exact moment of triggering coincides with lowering of the gear ("Gear" EH)
<sqf>
<sqf>
this addEventHandler ["Landing", {
this addEventHandler ["Landing", {
Line 765: Line 898:
* isCarrier: [[Boolean]] - true if landing on aircraft carrier
* isCarrier: [[Boolean]] - true if landing on aircraft carrier


{{ArgTitle|3|LandingCanceled|{{GVI|arma3|1.70}}}}


{{ArgTitle|4|LandingCanceled|{{GVI|arma3|1.70}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when AI pilot landing is cancelled (for example new order received to land elsewhere).
Triggered when AI pilot landing is cancelled (for example new order received to land elsewhere).
The exact moment of triggering coincides with retracting of the gear ("Gear" EH).
The exact moment of triggering coincides with retracting of the gear ("Gear" EH).<br>
'''Note''': Doesn't trigger if player switches off auto-pilot. Canceled is spelled with one L
'''Note''': Does not trigger if player switches off auto-pilot. Canceled is spelled with one {{hl|L}}
 
<sqf>
<sqf>
this addEventHandler ["LandingCanceled", {
this addEventHandler ["LandingCanceled", {
Line 781: Line 915:
* isCarrier: [[Boolean]] - [[true]] if landing on aircraft carrier
* isCarrier: [[Boolean]] - [[true]] if landing on aircraft carrier


{{ArgTitle|3|LeaningChanged|{{GVI|arma3|2.18}}}}
{{Icon|globalArgument|32}}<br>
Triggered when a soldier leaning factor is changed between -1 (extreme left), 0 (not leaning) and 1 (extreme right)
<sqf>
this addEventHandler ["LeaningChanged", {
params ["_unit", "_newLeaning", "_oldLeaning"];
}];
</sqf>
* unit: [[Object]] - soldier
* newLeaning: [[Number]] from -1 to 1
* oldLeaning: [[Number]] from -1 to 1
=== Local ===


==== Local ====
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when locality of object in MP is changed. The event handler only triggers on the computers that are directly involved in change of locality.
Triggers when locality of object in MP is changed. The event handler only triggers on the computers that are directly involved in change of locality.
So if EH is added to every computer on network, it will only trigger on 2 computers, on the computer that receives ownership of the object (new owner), in which case [[Magic Variables#this|_this]] [[select]] 1 will be [[true]],
So if EH is added to every computer on network, it will only trigger on 2 computers, on the computer that receives ownership of the object (new owner), in which case [[Magic Variables#this|_this]] [[select]] 1 will be [[true]],
and on the computer from which ownership is transferred (old owner), in which case [[Magic Variables#this|_this]] [[select]] 1 will be [[false]].
and on the computer from which ownership is transferred (old owner), in which case [[Magic Variables#this|_this]] [[select]] 1 will be [[false]].
<sqf>
<sqf>
this addEventHandler ["Local", {
this addEventHandler ["Local", {
Line 794: Line 944:


* entity: [[Object]] - the object that changed locality
* entity: [[Object]] - the object that changed locality
* local: [[Boolean]] - if the object is local on given computer
* isLocal: [[Boolean]] - if the object is local on given computer
 
{{ArgTitle|3|MagazineReloading|{{GVI|arma3|2.18}}}}
 
{{Icon|localArgument|32}}<br>
Triggers when a magazine is removed from a weapon manually or via script. Does NOT trigger on {{Link|#Reloaded}} event.
 
<sqf>
this addEventHandler ["MagazineReloading", {
params ["_unit", "_weapon", "_muzzle", "_magazine", "_magazineClass", "_ammoCount", "_magazineID", "_magazineCreator"];
}];
</sqf>
 
* unit: [[Object]] - unit or vehicle to which EH is assigned
* weapon: [[String]] - weapon that got unloaded
* muzzle: [[String]] - weapon's muzzle that got unloaded
* magazine: [[Array]] - magazine info in format [magazineClass, ammoCount, magazineID, magazineCreator], where:
** magazineClass: [[String]] - class name of the magazine
** ammoCount: [[Number]] - amount of ammo in magazine
** magazineID: [[Number]] - global magazine id
** magazineCreator: [[Number]] - owner of the magazine creator


{{ArgTitle|3|MagazineUnloaded|{{GVI|arma3|2.18}}}}
{{Icon|localArgument|32}}<br>
Triggers when a magazine is removed from a weapon manually or via script. Does NOT trigger on {{Link|#Reloaded}} event.
<sqf>
this addEventHandler ["MagazineUnloaded", {
params ["_unit", "_weapon", "_muzzle", "_magazine", "_magazineClass", "_ammoCount", "_magazineID", "_magazineCreator"];
}];
</sqf>
* unit: [[Object]] - unit or vehicle to which EH is assigned
* weapon: [[String]] - weapon that got unloaded
* muzzle: [[String]] - weapon's muzzle that got unloaded
* magazine: [[Array]] - magazine info in format [magazineClass, ammoCount, magazineID, magazineCreator], where:
** magazineClass: [[String]] - class name of the magazine
** ammoCount: [[Number]] - amount of ammo in magazine
** magazineID: [[Number]] - global magazine id
** magazineCreator: [[Number]] - owner of the magazine creator
{{ArgTitle|3|OpticsModeChanged|{{GVI|arma3|2.10}}}}


{{ArgTitle|4|OpticsModeChanged|{{GVI|arma3|2.10}}}}
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggers everytime a local unit changes optic mode. This could be either through the [[setOpticsMode]] command or by the player switching to the next optic mode using e.g {{Controls|NUM /}} or {{Controls|Ctrl|RMB}}.
Triggers everytime a local unit changes optic mode. This could be either through the [[setOpticsMode]] command or by the player switching to the next optic mode using e.g {{Controls|NUM /}} or {{Controls|Ctrl|RMB}}.
<sqf>
<sqf>
this addEventHandler ["OpticsModeChanged", {
this addEventHandler ["OpticsModeChanged", {
Line 812: Line 1,003:
* isADS: [[Boolean]] - if the new view is GUNNER
* isADS: [[Boolean]] - if the new view is GUNNER


{{ArgTitle|3|OpticsSwitch|{{GVI|arma3|2.10}}}}


{{ArgTitle|4|OpticsSwitch|{{GVI|arma3|2.10}}}}
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggers at the start of the camera transition from GUNNER to INTERNAL/EXTERNAL and vice-versa.
Triggers at the start of the camera transition from GUNNER to INTERNAL/EXTERNAL and vice-versa.
So anytime the right mouse button is pressed and there is a GUNNER view available or are currently in it, this triggers. Works in vehicles and FFV as well. See also [[cameraView]].
So anytime the right mouse button is pressed and there is a GUNNER view available or are currently in it, this triggers.
Works in vehicles and FFV as well. See also [[cameraView]].
 
<sqf>
<sqf>
this addEventHandler ["OpticsSwitch", {
this addEventHandler ["OpticsSwitch", {
Line 826: Line 1,019:
* isADS: [[Boolean]] - if the new view is GUNNER
* isADS: [[Boolean]] - if the new view is GUNNER


{{ArgTitle|3|PathCalculated|{{GVI|arma3|1.94}}}}


{{ArgTitle|4|PathCalculated|{{GVI|arma3|1.94}}}}
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggers when a path has been calculated for the unit. Works for both agents and normal AI units. <br>
Triggers when a path has been calculated for the unit. Works for both agents and normal AI units. <br>
Note that paths to far destinations are typically calculated in segments. When the unit completes a segment, a new path is calculated and this is continued until the unit reaches its destination.
Note that paths to far destinations are typically calculated in segments.
When the unit completes a segment, a new path is calculated and this is continued until the unit reaches its destination.
 
<sqf>
<sqf>
this addEventHandler ["PathCalculated", {
this addEventHandler ["PathCalculated", {
Line 840: Line 1,035:
* path: [[Array]] - the array of positions representing the path (PositionASL)
* path: [[Array]] - the array of positions representing the path (PositionASL)


{{ArgTitle|3|PeriscopeElevationChanged|{{GVI|arma3|2.00}}}}


{{ArgTitle|4|PeriscopeElevationChanged|{{GVI|arma3|2.00}}}}
Fires every frame during periscope elevation animation.
Fires every frame during periscope elevation animation.
<sqf>
<sqf>
this addEventHandler ["PeriscopeElevationChanged", {
this addEventHandler ["PeriscopeElevationChanged", {
params ["_vehicle", "_turret", "_elevation", "_direction", "_userisblocked"];
params ["_vehicle", "_turret", "_elevation", "_direction", "_userIsBlocked"];
}];
}];
</sqf>
</sqf>
Line 851: Line 1,047:
* vehicle: [[Object]] - the vehicle this EH is assigned to
* vehicle: [[Object]] - the vehicle this EH is assigned to
* turret: [[Array]] - the turret which periscope is changing elevation
* turret: [[Array]] - the turret which periscope is changing elevation
* elevation: [[Number]] - current periscope elevation (changes with each simulation). See also [[periscopeElevation]], [[elevatePeriscope]]  
* elevation: [[Number]] - current periscope elevation (changes with each simulation). See also [[periscopeElevation]], [[elevatePeriscope]]
* direction: [[Number]] - 1:moves up, 0:stopped, -1:moves down; when {{hl|direction}} returns 0, this also means the event handler fired for the last time for this elevation.
* direction: [[Number]] - 1: moves up, 0: stopped, -1: moves down; when {{hl|direction}} returns 0, this also means the event handler fired for the last time for this elevation.
* userisblocked: [[Boolean]] - whether or not the user ability to override is blocked. See also [[periscopeElevation]], [[elevatePeriscope]]
* userIsBlocked: [[Boolean]] - whether or not the user ability to override is blocked. See also [[periscopeElevation]], [[elevatePeriscope]]
 
{{ArgTitle|3|PostInit|{{GVI|arma3|2.06}}}}
 
{{Icon|globalArgument|32}}<br>
Triggered whenever an entity is created and initialized. Cannot be used in scripts, only inside class Eventhandlers in config.
{{Feature|important|It is recommended to use this event handler instead of the {{Link|#Init}} one when setting entity textures ([[setObjectTexture]], [[BIS_fnc_initVehicle]] etc) to avoid networking issues.}}
 
e.g:
<syntaxhighlight lang="cpp">postInit = "params ['_entity'];";</syntaxhighlight>
<syntaxhighlight lang="cpp">postinit = "params ['_entity']; if (local _entity) then { [_entity, '', [], false] call BIS_fnc_initVehicle };";</syntaxhighlight>
<sqf>params ["_entity"];</sqf>


* entity: [[Object]] - object the event handler is assigned to


==== PostReset ====
=== PostReset ===
Triggers after PP effects have been reset by the engine


'''Obsolete''' - triggers after PP effects have been reset by the engine.
{{ArgTitle|3|Put|{{GVI|arma3|0.56}}}}


{{ArgTitle|4|Put|{{GVI|arma3|0.56}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when a unit puts an item in a container.
Triggers when a unit puts an item in a container.
{{GVI|arma3|2.14|size= 0.75}} This event handler can be added to a container.
<sqf>
<sqf>
this addEventHandler ["Put", {
this addEventHandler ["Put", {
Line 869: Line 1,081:
</sqf>
</sqf>


* unit: [[Object]] - unit to which the event handler is assigned
* unit: [[Object]] - unit who put the item in the container
* container: [[Object]] - the container into which the item was placed (vehicle, box, etc.)
* container: [[Object]] - the container into which the item was placed (vehicle, box, etc.)
* item: [[String]] - the class name of the moved item
* item: [[String]] - the class name of the moved item


{{Feature|Informative|This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.}}
{{Feature|informative|This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.}}
 
{{ArgTitle|3|PylonChanged|{{GVI|arma3|2.20}}}}
 
{{Icon|localArgument|32}}<br>
Triggers when an aircraft's pylon changes magazine type:
 
<sqf>
vehicle player addEventHandler ["PylonChanged", {
params ["_vehicle", "_pylonIndex", "_oldMagazine", "_newMagazine"];
}];
</sqf>
 
* vehicle: [[Object]]
* pylonIndex: [[Number]]
* oldMagazine: [[String]]
* newMagazine: [[String]]
 
{{Feature|important|
This event generally triggers '''twice''' for a swap, first unload then load, e.g:
<sqf>
// [myVehicle, 1, "oldMagClass", ""]
// [myVehicle, 1, "", "newMagClass"]
</sqf>
}}
 
{{ArgTitle|3|Reloaded|{{GVI|arma3|1.58}}}}


{{ArgTitle|4|Reloaded|{{GVI|arma3|1.58}}}}
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggers when a weapon is reloaded with a new magazine. For more information see: [[Arma 3: Event Handlers/Reloaded|Reloaded]]
Triggers when a weapon is reloaded with a new magazine. For more information see: [[Arma 3: Event Handlers/Reloaded|Reloaded]]
<sqf>
<sqf>
this addEventHandler ["Reloaded", {
this addEventHandler ["Reloaded", {
Line 890: Line 1,128:
* oldMagazine: [[Array]] or [[Nothing]] - old magazine info
* oldMagazine: [[Array]] or [[Nothing]] - old magazine info


=== Respawn ===


==== Respawn ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a unit respawns.
Triggered when a unit respawns.
<sqf>
<sqf>
this addEventHandler ["Respawn", {
this addEventHandler ["Respawn", {
Line 903: Line 1,142:
* corpse: [[Object]] - object the event handler was assigned to, aka the corpse/unit player was previously controlling
* corpse: [[Object]] - object the event handler was assigned to, aka the corpse/unit player was previously controlling


{{ArgTitle|3|RopeAttach|{{GVI|arma3|1.34}}}}


{{ArgTitle|4|RopeAttach|{{GVI|arma3|1.34}}}}
Triggered when a rope is attached to an object.<br>
Triggered when a rope is attached to an object.<br>
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each attached rope.
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each attached rope.
<sqf>
<sqf>
this addEventHandler ["RopeAttach", {
this addEventHandler ["RopeAttach", {
Line 913: Line 1,153:
</sqf>
</sqf>


* object 1: [[Object]] - object to which the event handler is assigned.
* object1: [[Object]] - object to which the event handler is assigned.
* rope: [[Object]] - the rope being attached between object 1 and object 2.
* rope: [[Object]] - the rope being attached between object 1 and object 2.
* object 2: [[Object]] - the object that is being attached to object 1 via rope.
* object2: [[Object]] - the object that is being attached to object 1 via rope.


{{ArgTitle|3|RopeBreak|{{GVI|arma3|1.34}}}}


{{ArgTitle|4|RopeBreak|{{GVI|arma3|1.34}}}}
Triggered when a rope is detached from an object.<br>
Triggered when a rope is detached from an object.<br>
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each detached rope.
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each detached rope.
<sqf>
<sqf>
this addEventHandler ["RopeBreak", {
this addEventHandler ["RopeBreak", {
params ["_object1", "_rope", "_object2"];
params ["_rope", "_object1", "_object2"];
}];
}];
</sqf>
</sqf>


* object 1: [[Object]] - object to which the event handler is assigned.
* rope: [[Object]] - the rope that connected object 1 and object 2.
* rope: [[Object]] - the rope being detached between object 1 and object 2.
* object1: [[Object]] - object to which the event handler is assigned.
* object 2: [[Object]] - the object that is being detached from object 1 via rope.
* object2: [[Object]] - the object that was connected to object 1 with a rope.


{{ArgTitle|3|SeatSwitched|{{GVI|arma3|1.50}}}}


{{ArgTitle|4|SeatSwitched|{{GVI|arma3|1.50}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when unit changes seat within vehicle. EH returns both units switching seats.
Triggered when unit changes seat within vehicle. EH returns both units switching seats.
If switching seats with an empty seat, one of the returned units will be [[objNull]].
If switching seats with an empty seat, one of the returned units will be [[objNull]].
The new position can be obtained with [[assignedVehicleRole]] <unit>.
The new position can be obtained with [[assignedVehicleRole]].
This EH must be assigned to a vehicle.
This EH must be assigned to a vehicle.
<sqf>
<sqf>
this addEventHandler ["SeatSwitched", {
this addEventHandler ["SeatSwitched", {
Line 948: Line 1,190:
* unit2: [[Object]] - unit switching seat.
* unit2: [[Object]] - unit switching seat.


{{ArgTitle|3|SeatSwitchedMan|{{GVI|arma3|1.58}}}}


{{ArgTitle|4|SeatSwitchedMan|{{GVI|arma3|1.58}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggered when unit changes seat within vehicle. EH returns both units switching seats.
Triggered when unit changes seat within vehicle. EH returns both units switching seats.
Line 955: Line 1,197:
The new position can be obtained with [[assignedVehicleRole]] <unit>. This EH must be assigned to a unit and not a vehicle.
The new position can be obtained with [[assignedVehicleRole]] <unit>. This EH must be assigned to a unit and not a vehicle.
This EH is persistent and will be transferred to the new unit after respawn, but only if it was assigned where unit was local.
This EH is persistent and will be transferred to the new unit after respawn, but only if it was assigned where unit was local.
<sqf>
<sqf>
this addEventHandler ["SeatSwitchedMan", {
this addEventHandler ["SeatSwitchedMan", {
Line 965: Line 1,208:
* vehicle: [[Object]] - vehicle where switching seats is taking place.
* vehicle: [[Object]] - vehicle where switching seats is taking place.


=== SelectedActionChanged ===
RTM helicopter user action event


{{ArgTitle|4|SoundPlayed|{{GVI|arma3|0.56}}}}
{{Icon|localArgument|32}}<br>
Triggered when player is making noises when injured or fatigued for example. The number param passed to the EH code, points to the sound origin:
{{Columns|4|
# Breath
# Breath Injured
# Breath Scuba
# Injured
# Pulsation
# Hit Scream
# Burning
# Drowning
# Drown
# Gasping
# Stabilizing
# Healing
# Healing With Medikit
# Recovered
}}
<sqf>
<sqf>
this addEventHandler ["SoundPlayed", {
this addEventHandler ["SelectedActionChanged", {
params ["_unit", "_soundID"];
params ["_caller", "_target", "_enumNumber", "_actionId"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - Unit to which the event handler is assigned
{{Feature|important|Limited or non-existent functionality.}}
* soundID: [[Number]] - sound origin
 
{{Feature|Informative|Since {{GVI|arma3|2.12}} returning a [[Number]] from last added EH in range from 0 to 5 will alter the volume of played sound from mute to max volume}}
=== SelectedActionPerformed ===


RTM helicopter user action event


{{ArgTitle|4|Suppressed|{{GVI|arma3|2.02}}}}
{{Icon|localArgument|32}}<br>
Triggers when enemy projectile is passing by closer than defined suppression radius ammo value in config. Can be made to trigger for the same side if the side is set as enemy to itself (with [[setFriend]]).
<sqf>
<sqf>
this addEventHandler ["Suppressed", {
this addEventHandler ["SelectedActionPerformed", {
params ["_unit", "_distance", "_shooter", "_instigator", "_ammoObject", "_ammoClassName", "_ammoConfig"];
params ["_caller", "_target", "_enumNumber", "_actionId"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - unit to which the event is assigned
{{Feature|important|Limited or non-existent functionality.}}
* distance: [[Number]] - distance of the projectile pass-by
 
* shooter: [[Object]] - who (or what) fired - vehicle or drone
=== SelectedRotorLibActionChanged ===
* instigator: [[Object]] - who pressed the trigger. Instigator is different from the shooter when player is operator of UAV for example
* ammoObject: [[Object]] - the ammunition itself
* ammoClassName: [[String]] - the ammunition's classname
* ammoConfig: [[Config]] - the ammunition's [[CfgAmmo Config Reference|CfgAmmo]] config path


RTM helicopter user action event


{{ArgTitle|4|Take|{{GVI|arma3|0.56}}}}
{{Icon|globalArgument|32}}<br>
Triggers when a unit takes an item from a container.
<sqf>
<sqf>
this addEventHandler ["Take", {
this addEventHandler ["SelectedRotorLibActionChanged", {
params ["_unit", "_container", "_item"];
params ["_caller", "_target", "_enumNumber", "_actionId"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - unit to which the event handler is assigned
{{Feature|important|Limited or non-existent functionality.}}
* container: [[Object]] - the container from which the item was taken (vehicle, box, etc.)
* item: [[String]] - the class name of the taken item


{{Feature|Informative|This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.}}
=== SelectedRotorLibActionPerformed ===


RTM helicopter user action event


{{ArgTitle|4|TaskSetAsCurrent|{{GVI|arma3|1.32}}}}
Triggers when player's current task changes
<sqf>
<sqf>
this addEventHandler ["TaskSetAsCurrent", {
this addEventHandler ["SelectedRotorLibActionPerformed", {
params ["_unit", "_task"];
params ["_caller", "_target", "_enumNumber", "_actionId"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - the player to whom the event handler is assigned
{{Feature|important|
* task: [[Task]] - the new current task
Works only for key press combination {{Controls|RCtrl|W}}, which is the binding for helicopter wheels brakes.
It fires with or without Advanced Flight Model enabled. The enum number returned is 4 and 5, probably because the enum is structured like this:
* 0: HelicopterAutoTrimOn
* 1: HelicopterAutoTrimOff
* 2: HelicopterTrimOn
* 3: HelicopterTrimOff
* 4: WheelsBrakeOn
* 5: WheelsBrakeOff
}}


{{ArgTitle|3|SlotItemChanged|{{GVI|arma3|2.14}}}}


{{ArgTitle|4|TurnIn|{{GVI|arma3|1.66}}}}
{{Icon|globalArgument|32}}<br>
Triggers when member of crew in a vehicle uses Turn In [[action]]
Triggered when any of the following slots get assigned or unassigned: ''Items'' - Map, GPS, Radio, Watch, Compass, Helmet, Goggles, NVG; ''Weapon'' - Binoculars; ''Containers'' - Uniform, Vest, Backpack.
<sqf>
this addEventHandler ["TurnIn", {
params ["_vehicle", "_unit", "_turret"];
}];
</sqf>
 
* vehicle: [[Object]] - the vehicle the event handler is assigned to
* unit: [[Object]] - the unit performing the Turn In action
* turret: [[Array]] - turret path
 


{{ArgTitle|4|TurnOut|{{GVI|arma3|1.66}}}}
Triggers when member of crew in a vehicle uses Turn Out [[action]]
<sqf>
<sqf>
this addEventHandler ["TurnOut", {
this addEventHandler ["SlotItemChanged", {
params ["_vehicle", "_unit", "_turret"];
params ["_unit", "_name", "_slot", "_assigned", "_weapon"];
}];
}];
</sqf>
</sqf>


* vehicle: [[Object]] - the vehicle the event handler is assigned to
* unit: [[Object]] - unit EH assigned to.
* unit: [[Object]] - the unit performing the Turn Out action
* name: [[String]] - name of the item/weapon/container (see [[getSlotItemName]]).
* turret: [[Array]] - turret path
* slot: [[Number]] - slot id (see [[getSlotItemName]]).
* assigned: [[Boolean]] - [[true]] assign action, [[false]] unassign action.
* {{GVI|arma3|2.18}} weapon: [[String]] - name of weapon in event that slot changed is a weapon attachment slot


{{ArgTitle|4|VisionModeChanged|{{GVI|arma3|2.08}}}}
{{ArgTitle|3|SoundPlayed|{{GVI|arma3|0.56}}}}
Triggers when the assigned vehicle/unit's vision mode has changed.
<sqf>
player addEventHandler ["VisionModeChanged", {
params ["_person", "_visionMode", "_TIindex", "_visionModePrev", "_TIindexPrev", "_vehicle", "_turret"];
}];
</sqf>


Desc WIP
{{Icon|localArgument|32}}<br>
* person: [[Object]] - unit for whom the vision mode changes
Triggered when player is making noises when injured or fatigued for example. The number param passed to the EH code points to the sound origin:
* visionMode: [[Number]] - [[currentVisionMode|vision mode index]]
{{Columns|3|
* TIindex: [[Number]] - [[setCamUseTI|thermal vision mode index]]; will return -1 when ''visionMode'' is not 2
# Breath
* visionModePrev: [[Number]] - last vision mode
# Breath Injured
* TIindexPrev: [[Number]] - last TI mode; will return -1 when ''visionModePrev'' is not 2
# Breath Scuba
* vehicle: [[Object]] - if unit is in a vehicle or controlling a UAV, this will be the vehicle
# Injured
* turret: [[Array]] - turret path to the turret occupied by the unit, or [] if not on turret
# Pulsation
# Hit Scream
# Burning
# Drowning
# Drown
# Gasping
# Stabilizing
# Healing
# Healing With Medikit
# Recovered
# Breath Held
}}


==== WeaponAssembled ====
{{Icon|globalArgument|32}}<br>
Triggers when weapon gets assembled. EH should be attached to the unit and not the weapon.
<sqf>
<sqf>
this addEventHandler ["WeaponAssembled", {
this addEventHandler ["SoundPlayed", {
params ["_unit", "_staticWeapon"];
params ["_unit", "_soundID"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - unit to which the event handler is assigned
* weapon: [[Object]] - object of the assembled weapon
* soundID: [[Number]] - sound origin


{{Feature|informative|Since {{GVI|arma3|2.12}} returning a [[Number]] from last added EH in range from 0 to 5 will alter the volume of played sound from mute to max volume.}}
{{ArgTitle|3|Suppressed|{{GVI|arma3|2.02}}}}
{{Icon|localArgument|32}}<br>
Triggers when enemy projectile is passing by closer than defined suppression radius ammo value in config.
Can be made to trigger for the same side if the side is set as enemy to itself (with [[setFriend]]).


==== WeaponDisassembled ====
{{Icon|globalArgument|32}}<br>
Triggers when weapon gets disassembled. EH should be attached to the unit and not the weapon.<br><br>
'''NOTE:''' As of Arma 3 v1.32, this event does not fire if the weapon is not local. See http://feedback.arma3.com/view.php?id=21308
<sqf>
<sqf>
this addEventHandler ["WeaponDisassembled", {
this addEventHandler ["Suppressed", {
params ["_unit", "_primaryBag", "_secondaryBag"];
params ["_unit", "_distance", "_shooter", "_instigator", "_ammoObject", "_ammoClassName", "_ammoConfig"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - unit to which the event is assigned
* primaryBag: [[Object]] - first backpack object which was weapon disassembled into
* distance: [[Number]] - distance of the projectile pass-by
* secondaryBag: [[Object]] - second backpack object which was weapon disassembled into
* shooter: [[Object]] - who (or what) fired - vehicle or drone
* instigator: [[Object]] - who pressed the trigger. Instigator is different from the shooter when player is operator of UAV for example
* ammoObject: [[Object]] - the ammunition itself
* ammoClassName: [[String]] - the ammunition's classname
* ammoConfig: [[Config]] - the ammunition's [[CfgAmmo Config Reference|CfgAmmo]] config path


{{ArgTitle|3|Take|{{GVI|arma3|0.56}}}}


{{ArgTitle|4|WeaponDeployed|{{GVI|arma3|1.44}}}}
{{Icon|globalArgument|32}}<br>
{{Icon|globalArgument|32}}<br>
Triggers when the deployed state of a weapon or bipod changes. Note: A weapon cannot be rested and deployed at the same time.
Triggers when a unit takes an item from a container.
 
{{GVI|arma3|2.14|size= 0.75}} This event handler can be added to a container.
 
<sqf>
<sqf>
this addEventHandler ["WeaponDeployed", {
this addEventHandler ["Take", {
params ["_unit", "_isDeployed"];
params ["_unit", "_container", "_item"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - unit who took the item from the container
* isDeployed: [[Boolean]] - true if deployed
* container: [[Object]] - the container from which the item was taken (vehicle, box, etc.)
* item: [[String]] - the class name of the taken item
 
{{Feature|informative|This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.}}


{{ArgTitle|3|TaskSetAsCurrent|{{GVI|arma3|1.32}}}}
Triggers when player's current task changes


{{ArgTitle|4|WeaponRested|{{GVI|arma3|1.44}}}}
{{Icon|localArgument|32}}<br>
Triggers when weapon rested state changes (weapon near a surface that can provide weapon support).
Note: A weapon cannot be rested and deployed at the same time.
<sqf>
<sqf>
this addEventHandler ["WeaponRested", {
this addEventHandler ["TaskSetAsCurrent", {
params ["_unit", "_isRested"];
params ["_unit", "_task"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* unit: [[Object]] - the player to whom the event handler is assigned
* isRested: [[Boolean]] - true if rested
* task: [[Task]] - the new current task
 
{{ArgTitle|3|TurnIn|{{GVI|arma3|1.66}}}}
 
Triggers when member of crew in a vehicle uses Turn In [[action]]


==== SelectedActionPerformed ====
RTM helicopter user action event
<sqf>
<sqf>
this addEventHandler ["SelectedActionPerformed", {
this addEventHandler ["TurnIn", {
params ["_caller", "_target", "_enumNumber", "_actionId"];
params ["_vehicle", "_unit", "_turret"];
}];
}];
</sqf>
</sqf>


{{Feature|important|Limited or non-existent functionality}}  
* vehicle: [[Object]] - the vehicle the event handler is assigned to
* unit: [[Object]] - the unit performing the Turn In action
* turret: [[Array]] - turret path
 
{{ArgTitle|3|TurnOut|{{GVI|arma3|1.66}}}}
 
Triggers when member of crew in a vehicle uses Turn Out [[action]]


==== SelectedActionChanged ====
RTM helicopter user action event
<sqf>
<sqf>
this addEventHandler ["SelectedActionChanged", {
this addEventHandler ["TurnOut", {
params ["_caller", "_target", "_enumNumber", "_actionId"];
params ["_vehicle", "_unit", "_turret"];
}];
}];
</sqf>
</sqf>


{{Feature|important|Limited or non-existent functionality}}  
* vehicle: [[Object]] - the vehicle the event handler is assigned to
* unit: [[Object]] - the unit performing the Turn Out action
* turret: [[Array]] - turret path
 
{{ArgTitle|3|VisionModeChanged|{{GVI|arma3|2.08}}}}
 
Triggers when the assigned vehicle/unit's vision mode has changed.


==== SelectedRotorLibActionPerformed ====
RTM helicopter user action event
<sqf>
<sqf>
this addEventHandler ["SelectedRotorLibActionPerformed", {
player addEventHandler ["VisionModeChanged", {
params ["_caller", "_target", "_enumNumber", "_actionId"];
params ["_person", "_visionMode", "_TIindex", "_visionModePrev", "_TIindexPrev", "_vehicle", "_turret"];
}];
}];
</sqf>
</sqf>


{{Feature|important|Works only for key press combination {{Controls|RCtrl|W}}, which is the binding for helicopter wheels brakes. It fires with or without Advanced Flight Model enabled. The enum number returned is 4 and 5, probably because the enum is structured like this:
* person: [[Object]] - unit for whom the vision mode changes
* 0: HelicopterAutoTrimOn
* visionMode: [[Number]] - [[currentVisionMode|vision mode index]]
* 1: HelicopterAutoTrimOff
* TIindex: [[Number]] - [[setCamUseTI|thermal vision mode index]]; will return -1 when ''visionMode'' is not 2
* 2: HelicopterTrimOn
* visionModePrev: [[Number]] - last vision mode
* 3: HelicopterTrimOff
* TIindexPrev: [[Number]] - last TI mode; will return -1 when ''visionModePrev'' is not 2
* 4: WheelsBrakeOn
* vehicle: [[Object]] - if unit is in a vehicle or controlling a UAV, this will be the vehicle
* 5: WheelsBrakeOff
* turret: [[Array]] - turret path to the turret occupied by the unit, or [] if not on turret
}}  
 
=== WeaponAssembled ===
 
{{Icon|globalArgument|32}}<br>
Triggers when a weapon gets assembled. EH must be attached to the unit and not the weapon.


==== SelectedRotorLibActionChanged ====
RTM helicopter user action event
<sqf>
<sqf>
this addEventHandler ["SelectedRotorLibActionChanged", {
this addEventHandler ["WeaponAssembled", {
params ["_caller", "_target", "_enumNumber", "_actionId"];
params ["_unit", "_weapon", "_primaryBag", "_secondaryBag"];
}];
}];
</sqf>
</sqf>


{{Feature|important|Limited or non-existent functionality}}  
* unit: [[Object]] - object the event handler is assigned to
{{ConfigPage|end}}
* weapon: [[Object]] - object of the assembled weapon
* {{GVI|arma3|2.18}} primaryBag: [[Object]] - primary bag (just before it is deleted)
* {{GVI|arma3|2.18}} secondaryBag: [[Object]] - secondary bag (just before it is deleted)
 
{{ArgTitle|3|WeaponChanged|{{GVI|arma3|2.18}}}}
 
Fires on weapon switch and firemode switch. Does not fire for player units inside vehicles (but does fire for vehicles with players in them).<br>
The locality is unknown, but it is known that this EH behaves like [[currentWeapon]], [[currentWeaponMode]] and [[currentMuzzle]] in terms of locality.
 
<sqf>
this addEventHandler ["WeaponChanged", {
params ["_object", "_oldWeapon", "_newWeapon", "_oldMode", "_newMode", "_oldMuzzle", "_newMuzzle", "_turretIndex"];
}];
</sqf>


* object: [[Object]] - the unit or vehicle the event handler is assigned to
* oldWeapon: [[String]] - the class name of the previous weapon
* newWeapon: [[String]] - the class name of the new weapon (same as [[currentWeapon]])
* oldMode: [[String]] - the previous weapon mode
* newMode: [[String]] - the new weapon mode (same as [[currentWeaponMode]])
* oldMuzzle: [[String]] - the previous weapon muzzle
* newMuzzle: [[String]] - the new weapon muzzle (same as [[currentMuzzle]])
* turretIndex: [[Array]] format [[Turret Path]] - the turret path, or [[nil]] if <var>object</var> is not a transport vehicle


{{ArgTitle|3|Curator|{{GVI|arma3|1.16}}}}
{{ArgTitle|3|WeaponDeployed|{{GVI|arma3|1.44}}}}
{{Icon|localArgument|32}}{{Icon|localEffect|32}}<br>
 
[[Arma 3: Curator]] Event Handlers are also added with the [[addEventHandler]] command. They are executed only where the curator is local - on the machine that is in control of it.
{{Icon|globalArgument|32}}<br>
{{Feature|important|These Event Handlers must be added to the curator object/module, '''not''' the player!}}
Triggers when the deployed state of a weapon or bipod changes.<br>
'''Note:''' A weapon cannot be rested and deployed at the same time.


{{ConfigPage|start}}
<sqf>
{{ConfigPage|abc}}
this addEventHandler ["WeaponDeployed", {
==== CuratorFeedbackMessage ====
params ["_unit", "_isDeployed"];
{{Icon|localArgument|32}}<br>
}];
Triggered when curator attempts invalid action in curator interface.
</sqf>
 
* unit: [[Object]] - object the event handler is assigned to
* isDeployed: [[Boolean]] - true if deployed
 
=== WeaponDisassembled ===
 
{{Icon|globalArgument|32}}<br>
Triggers when a weapon gets disassembled. EH must be attached to the unit and not the weapon.<br>
'''Note:''' As of {{arma3}} v1.32, this event does not fire if the weapon is not local.


Each error has its own unique ID, recognized values are:
<spoiler text="show errors list">
* 003 - when trying to teleport camera outside of [[curatorCameraArea]]
* 101 - trying to place an object when placing is disabled using [[setCuratorCoef]] "place"
* 102 - trying to place an object which is too expensive (cost set in ''curatorObjectRegistered'' multiplied by [[setCuratorCoef]] "place" is larger than [[curatorPoints]])
* 103 - trying to place an object outside of [[curatorEditingArea]]
* 104 - items of a placed composition were skipped / could not be placed (since {{arma3}} v2.06)
* 201 - trying to place a waypoint when waypoint placing is disabled
* 202 - trying to place a waypoint which is too expensive (cost set by [[setCuratorWaypointCost]] multiplied by [[setCuratorCoef]] "place" is larger than [[curatorPoints]])
* 206 - trying to place a waypoint when no AI unit is selected
* 301 - trying to move or rotate an entity when editing is disabled using [[setCuratorCoef]] "edit"
* 302 - trying to move or rotate an entity when it is too expensive (entity cost multiplied by [[setCuratorCoef]] "edit" is larger than [[curatorPoints]])
* 303 - trying to move an entity outside of [[curatorEditingArea]]
* 304 - trying to move or rotate an entity which is outside of [[curatorEditingArea]]
* 307 - trying to move or rotate a player (players cannot be manipulated with)
* 401 - trying to delete an entity when deleting is disabled using [[setCuratorCoef]] "delete"
* 402 - trying to delete an entity which is too expensive (cost multiplied by [[setCuratorCoef]] "delete" is larger than [[curatorPoints]])
* 404 - trying to delete an entity which is outside of [[curatorEditingArea]]
* 405 - trying to delete an entity which has [[curatorEditableObjects|non-editable]] crew in it
* 407 - trying to delete a player (players cannot be manipulated with)
* 501 - trying to destroy an object when destroying is disabled using [[setCuratorCoef]] "destroy"
* 502 - trying to destroy an object which is too expensive (cost multiplied by [[setCuratorCoef]] "destroy" is larger than [[curatorPoints]])
* 504 - trying to destroy an object which is outside of [[curatorEditingArea]]
* 505 - trying to destroy an object which has [[curatorEditableObjects|non-editable]] crew in it
* 506 - trying to destroy an object when no object is selected
* 507 - trying to destroy a player (players cannot be manipulated with)
</spoiler>
<sqf>
<sqf>
this addEventHandler ["CuratorFeedbackMessage", {
this addEventHandler ["WeaponDisassembled", {
params ["_curator", "_errorID"];
params ["_unit", "_primaryBag", "_secondaryBag", "_weapon"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* unit: [[Object]] - object the event handler is assigned to
* errorID: [[Number]]
* primaryBag: [[Object]] - first backpack object which was weapon disassembled into
 
* secondaryBag: [[Object]] - second backpack object which was weapon disassembled into
* {{GVI|arma3|2.18}} weapon: [[Object]] - disassembled weapon (just before it is moved out of the world)
 
{{ArgTitle|3|WeaponRested|{{GVI|arma3|1.44}}}}


==== CuratorGroupDoubleClicked ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a group is double-clicked on in curator interface.
Triggers when weapon rested state changes (weapon near a surface that can provide weapon support).<br>
'''Note:''' A weapon cannot be rested and deployed at the same time.
 
<sqf>
<sqf>
this addEventHandler ["CuratorGroupDoubleClicked", {
this addEventHandler ["WeaponRested", {
params ["_curator", "_group"];
params ["_unit", "_isRested"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* unit: [[Object]] - object the event handler is assigned to
* group: [[Group]]
* isRested: [[Boolean]] - true if rested
 


== Multiplayer Event Handlers ==


==== CuratorGroupPlaced ====
Global object event handler, executed on every connected machine.
{{Icon|localArgument|32}}<br>
Triggered when new group is placed in curator interface.
<sqf>
this addEventHandler ["CuratorGroupPlaced", {
params ["_curator", "_group"];
}];
</sqf>


* curator: [[Object]]
Commands:
* group: [[Group]]
* [[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.}}


==== CuratorGroupSelectionChanged ====
=== MPHit ===
{{Icon|localArgument|32}}<br>
 
Triggered when a group is selected in curator interface.
{{Icon|globalArgument|32}}{{Icon|globalEffect|32}}<br>
<sqf>
Triggered when the unit is hit/damaged. EH can be added on any machine and EH code will trigger globally on every connected client and server.
this addEventHandler ["CuratorGroupSelectionChanged", {
This EH is clever enough to be triggered globally only once even if added on all clients or a single client that is then disconnected, EH will still trigger globally only once.
params ["_curator", "_group"];
}];
</sqf>


* curator: [[Object]]
Is ''not'' always triggered when unit is killed by a hit.
* group: [[Group]]
Most of the time only the [[#Killed|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.
Can also trigger several times for an explosion (direct and indirect damage). Does not fire when a unit is set to [[allowDamage]] [[false]].
However it will fire with "HandleDamage" EH added alongside stopping unit from taking damage (<sqf inline>unit addEventHandler ["HandleDamage", { 0 }];</sqf>.
Will not trigger once the unit is dead.


'''Note:''' call a function from the MPHit EH code space rather than defining 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!


==== CuratorMarkerDeleted ====
{{Icon|localArgument|32}}<br>
Triggered when a marker is deleted in curator interface.
<sqf>
<sqf>
this addEventHandler ["CuratorMarkerDeleted", {
this addMPEventHandler ["MPHit", {
params ["_curator", "_marker"];
params ["_unit", "_causedBy", "_damage", "_instigator"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* unit: [[Object]] - object the event handler is assigned to <br>
* marker: [[String]]
* causedBy: [[Object]] - object that caused the damage. Contains the unit itself in case of collisions. <br>
* damage: [[Number]] - level of damage caused by the hit
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger


=== MPKilled ===
{{Icon|globalArgument|32}}{{Icon|globalEffect|32}}<br>
Triggered when the unit is killed. EH can be added on any machine and EH code will trigger globally '''on every connected client and server'''.
This EH has a safeguard measure so that even if it's added on all clients or a single client that is then disconnected, EH will still trigger globally only once per client.


==== CuratorMarkerDoubleClicked ====
{{Icon|localArgument|32}}<br>
Triggered when a marker is double-clicked on in curator interface.
<sqf>
<sqf>
this addEventHandler ["CuratorMarkerDoubleClicked", {
this addMPEventHandler ["MPKilled", {
params ["_curator", "_marker"];
params ["_unit", "_killer", "_instigator", "_useEffects"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* unit: [[Object]] - object the event handler is assigned to
* marker: [[String]]
* killer: [[Object]] - object that killed the unit. Contains the unit itself in case of collisions
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.68}} useEffects: [[Boolean]] - same as ''useEffects'' in [[setDamage]] alt syntax
 
=== MPRespawn ===


{{Icon|globalArgument|32}}{{Icon|localEffect|32}}<br>
Triggered when a unit, it is assigned to, respawns. This EH does not work as one would expect MP EH should work like.
It is only triggered on one machine where the unit it was assigned to is [[Multiplayer Scripting#Locality|local]].
The only difference between '''Respawn''' and '''MPRespawn''' is that '''MPRespawn''' can be assigned from anywhere while '''Respawn''' requires the unit to be local.<br><br>
MPRespawn EH expects the EH code to return an array in [[Position]] format which will be used to place the respawned unit at the desired coordinates.<br>
For example: <sqf inline>player addMPEventHandler ["MPRespawn", { [1234, 1234, 0] }];</sqf> will place player at [1234,1234,0] immediately on respawn.


==== CuratorMarkerEdited ====
{{Icon|localArgument|32}}<br>
Triggered when a marker is moved in curator interface.
<sqf>
<sqf>
this addEventHandler ["CuratorMarkerEdited", {
this addMPEventHandler ["MPRespawn", {
params ["_curator", "_marker"];
params ["_unit", "_corpse"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* unit: [[Object]] - object the event handler is assigned to
* marker: [[String]]
* corpse: [[Object]] - object the event handler was assigned to, aka the corpse/unit player was previously controlling.




==== CuratorMarkerPlaced ====
== Mission Event Handlers ==
{{Icon|localArgument|32}}<br>
Triggered when new marker is placed in curator interface.
<sqf>
this addEventHandler ["CuratorMarkerPlaced", {
params ["_curator", "_marker"];
}];
</sqf>


* curator: [[Object]]
Mission Event Handlers are specific EHs that are anchored to the running mission and automatically removed when mission is over.
* marker: [[String]]


Commands:
* [[addMissionEventHandler]]
* [[removeMissionEventHandler]]


==== CuratorMarkerSelectionChanged ====
{{Feature|informative|See [[Arma 3: Mission Event Handlers]].}}
{{Icon|localArgument|32}}<br>
Triggered when a marker is selected in curator interface.
<sqf>
this addEventHandler ["CuratorMarkerSelectionChanged", {
params ["_curator", "_marker"];
}];
</sqf>


* curator: [[Object]]
{{ArgTitle|2|Curator Event Handlers|{{GVI|arma3|1.16}}}}
* marker: [[String]]


{{Icon|localArgument|32}}{{Icon|localEffect|32}}<br>
[[Arma 3: Curator]] Event Handlers are also added with the [[addEventHandler]] command. They are executed only where the curator is local - on the machine that is in control of it.
{{Feature|important|These Event Handlers must be added to the curator object/module, '''not''' the player!}}


==== CuratorObjectDeleted ====
Commands:
{{Icon|localArgument|32}}<br>
* [[addEventHandler]]
Triggered when an object is deleted in curator interface.
* [[removeEventHandler]]
<sqf>
* [[removeAllEventHandlers]]
this addEventHandler ["CuratorObjectDeleted", {
params ["_curator", "_entity"];
}];
</sqf>
 
* curator: [[Object]]
* entity: [[Object]]


=== CuratorFeedbackMessage ===


==== CuratorObjectDoubleClicked ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when an object is double-clicked on in curator interface.
Triggered when curator attempts invalid action in curator interface.
<sqf>
 
this addEventHandler ["CuratorObjectDoubleClicked", {
Each error has its own unique ID, recognized values are:
params ["_curator", "_entity"];
<spoiler text="show errors list">
}];
* 003 - when trying to teleport camera outside of [[curatorCameraArea]]
</sqf>
* 101 - trying to place an object when placing is disabled using [[setCuratorCoef]] "place"
* 102 - trying to place an object which is too expensive (cost set in ''curatorObjectRegistered'' multiplied by [[setCuratorCoef]] "place" is larger than [[curatorPoints]])
* 103 - trying to place an object outside of [[curatorEditingArea]]
* 104 - items of a placed composition were skipped / could not be placed (since {{arma3}} v2.06)
* 201 - trying to place a waypoint when waypoint placing is disabled
* 202 - trying to place a waypoint which is too expensive (cost set by [[setCuratorWaypointCost]] multiplied by [[setCuratorCoef]] "place" is larger than [[curatorPoints]])
* 206 - trying to place a waypoint when no AI unit is selected
* 301 - trying to move or rotate an entity when editing is disabled using [[setCuratorCoef]] "edit"
* 302 - trying to move or rotate an entity when it is too expensive (entity cost multiplied by [[setCuratorCoef]] "edit" is larger than [[curatorPoints]])
* 303 - trying to move an entity outside of [[curatorEditingArea]]
* 304 - trying to move or rotate an entity which is outside of [[curatorEditingArea]]
* 307 - trying to move or rotate a player (players cannot be manipulated with)
* 401 - trying to delete an entity when deleting is disabled using [[setCuratorCoef]] "delete"
* 402 - trying to delete an entity which is too expensive (cost multiplied by [[setCuratorCoef]] "delete" is larger than [[curatorPoints]])
* 404 - trying to delete an entity which is outside of [[curatorEditingArea]]
* 405 - trying to delete an entity which has [[curatorEditableObjects|non-editable]] crew in it
* 407 - trying to delete a player (players cannot be manipulated with)
* 501 - trying to destroy an object when destroying is disabled using [[setCuratorCoef]] "destroy"
* 502 - trying to destroy an object which is too expensive (cost multiplied by [[setCuratorCoef]] "destroy" is larger than [[curatorPoints]])
* 504 - trying to destroy an object which is outside of [[curatorEditingArea]]
* 505 - trying to destroy an object which has [[curatorEditableObjects|non-editable]] crew in it
* 506 - trying to destroy an object when no object is selected
* 507 - trying to destroy a player (players cannot be manipulated with)
</spoiler>


* curator: [[Object]]
* entity: [[Object]]
==== CuratorObjectEdited ====
{{Icon|localArgument|32}}<br>
Triggered when an object is moved or rotated in curator interface.
<sqf>
<sqf>
this addEventHandler ["CuratorObjectEdited", {
this addEventHandler ["CuratorFeedbackMessage", {
params ["_curator", "_entity"];
params ["_curator", "_errorID"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* entity: [[Object]]
* errorID: [[Number]]


=== CuratorGroupDoubleClicked ===


==== CuratorObjectPlaced ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when new object is placed in curator interface.
Triggered when a group is double-clicked on in curator interface.
This event handler will trigger individually for each unit in a placed group - excluding the crew in vehicles.
 
<sqf>
<sqf>
this addEventHandler ["CuratorObjectPlaced", {
this addEventHandler ["CuratorGroupDoubleClicked", {
params ["_curator", "_entity"];
params ["_curator", "_group"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* entity: [[Object]]
* group: [[Group]]


=== CuratorGroupPlaced ===


==== CuratorObjectRegistered ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when player enters curator interface. Assign curator cost to every object in the game.
Triggered when new group is placed in curator interface.
This is the primary method that a mission designer can use to limit the objects a curator can place.<br>
{{Feature|informative|See {{Link|Curator#Manual Assigning}}.}}


<sqf>
<sqf>
this addEventHandler ["CuratorObjectRegistered", {
this addEventHandler ["CuratorGroupPlaced", {
params ["_curator", "_input"];
params ["_curator", "_group"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* input: [[Array]] of [[String]]s - all [[Arma 3: Assets|CfgVehicles]] classes
* group: [[Group]]


=== CuratorGroupSelectionChanged ===


==== CuratorObjectSelectionChanged ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when an object is selected in curator interface.
Triggered when a group is selected in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorObjectSelectionChanged", {
this addEventHandler ["CuratorGroupSelectionChanged", {
params ["_curator", "_entity"];
params ["_curator", "_group"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* entity: [[Object]]
* group: [[Group]]


=== CuratorMarkerDeleted ===


==== CuratorPinged ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a player pings his curator(s) by pressing ''Zeus'' key.
Triggered when a marker is deleted in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorPinged", {
this addEventHandler ["CuratorMarkerDeleted", {
params ["_curator", "_player"];
params ["_curator", "_marker"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* player: [[Object]]
* marker: [[String]]


=== CuratorMarkerDoubleClicked ===


==== CuratorWaypointDeleted ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a waypoint is deleted in curator interface.
Triggered when a marker is double-clicked on in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorWaypointDeleted", {
this addEventHandler ["CuratorMarkerDoubleClicked", {
params ["_curator", "_waypoint"];
params ["_curator", "_marker"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* waypoint: [[Array]]
* marker: [[String]]


=== CuratorMarkerEdited ===


==== CuratorWaypointDoubleClicked ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a waypoint is double-clicked on in curator interface.
Triggered when a marker is moved in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorWaypointDoubleClicked", {
this addEventHandler ["CuratorMarkerEdited", {
params ["_curator", "_waypoint"];
params ["_curator", "_marker"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* waypoint: [[Array]]
* marker: [[String]]


=== CuratorMarkerPlaced ===


==== CuratorWaypointEdited ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a waypoint is moved in curator interface.
Triggered when new marker is placed in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorWaypointEdited", {
this addEventHandler ["CuratorMarkerPlaced", {
params ["_curator", "_waypoint"];
params ["_curator", "_marker"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* waypoint: [[Array]]
* marker: [[String]]


=== CuratorMarkerSelectionChanged ===


==== CuratorWaypointPlaced ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when new waypoint is placed in curator interface.
Triggered when a marker is selected in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorWaypointPlaced", {
this addEventHandler ["CuratorMarkerSelectionChanged", {
params ["_curator", "_group", "_waypointID"];
params ["_curator", "_marker"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* group: [[Group]]
* marker: [[String]]
* waypointID: [[Number]]


=== CuratorObjectDeleted ===


==== CuratorWaypointSelectionChanged ====
{{Icon|localArgument|32}}<br>
{{Icon|localArgument|32}}<br>
Triggered when a waypoint is selected in curator interface.
Triggered when an object is deleted in curator interface.
 
<sqf>
<sqf>
this addEventHandler ["CuratorWaypointSelectionChanged", {
this addEventHandler ["CuratorObjectDeleted", {
params ["_curator", "_waypoint"];
params ["_curator", "_entity"];
}];
}];
</sqf>
</sqf>


* curator: [[Object]]
* curator: [[Object]]
* waypoint: [[Array]]
* entity: [[Object]]
{{ConfigPage|end}}


=== CuratorObjectDoubleClicked ===


== Multiplayer Event Handlers ==
{{Icon|localArgument|32}}<br>
Triggered when an object is double-clicked on in curator interface.


Global object event handler, executed on every connected machine.
<sqf>
 
this addEventHandler ["CuratorObjectDoubleClicked", {
Commands:
params ["_curator", "_entity"];
* [[addMPEventHandler]]
}];
* [[removeMPEventHandler]]
</sqf>
* [[removeAllMPEventHandlers]]


{{ConfigPage|start}}
* curator: [[Object]]
{{ConfigPage|abc}}
* entity: [[Object]]
==== MPHit ====
{{Icon|globalArgument|32}}{{Icon|globalEffect|32}}<br>
Triggered when the unit is hit/damaged. EH can be added on any machine and EH code will trigger globally on every connected client and server.
This EH is clever enough to be triggered globally only once even if added on all clients or a single client that is then disconnected, EH will still trigger globally only once.


Is ''not'' always triggered when unit is killed by a hit.
=== CuratorObjectEdited ===
Most of the time only the [[ArmA_3:_Event_Handlers#Killed|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.
Can also trigger several times for an explosion (direct and indirect damage). Does not fire when a unit is set to [[allowDamage]] [[false]].
However it will fire with "HandleDamage" EH added alongside stopping unit from taking damage (<sqf inline>unit addEventHandler ["HandleDamage", { 0 }];</sqf>.
Will not trigger once the unit is dead.


Note: call a function from the MPHit EH code space rather than defining the full code in there directly.
{{Icon|localArgument|32}}<br>
The reason is the code space will be transferred over network on each event activation - so keep the data as small as possible!
Triggered when an object is moved or rotated in curator interface.


<sqf>
<sqf>
this addMPEventHandler ["MPHit", {
this addEventHandler ["CuratorObjectEdited", {
params ["_unit", "_causedBy", "_damage", "_instigator"];
params ["_curator", "_entity"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to <br>
* curator: [[Object]]
* causedBy: [[Object]] - object that caused the damage. Contains the unit itself in case of collisions. <br>
* entity: [[Object]]
* damage: [[Number]] - level of damage caused by the hit
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger


=== CuratorObjectPlaced ===


==== MPKilled ====
{{Icon|localArgument|32}}<br>
{{Icon|globalArgument|32}}{{Icon|globalEffect|32}}<br>
Triggered when new object is placed in curator interface.
Triggered when the unit is killed. EH can be added on any machine and EH code will trigger globally '''on every connected client and server'''.
This event handler will trigger individually for each unit in a placed group - excluding the crew in vehicles.
This EH has a safeguard measure so that even if it's added on all clients or a single client that is then disconnected, EH will still trigger globally only once per client.


<sqf>
<sqf>
this addMPEventHandler ["MPKilled", {
this addEventHandler ["CuratorObjectPlaced", {
params ["_unit", "_killer", "_instigator", "_useEffects"];
params ["_curator", "_entity"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* curator: [[Object]]
* killer: [[Object]] - object that killed the unit. Contains the unit itself in case of collisions
* entity: [[Object]]
* {{GVI|arma3|1.66}} instigator: [[Object]] - person who pulled the trigger
* {{GVI|arma3|1.68}} useEffects: [[Boolean]] - same as ''useEffects'' in [[setDamage]] alt syntax


=== CuratorObjectRegistered ===


==== MPRespawn ====
{{Icon|localArgument|32}}<br>
{{Icon|globalArgument|32}}{{Icon|localEffect|32}}<br>
Triggered when player enters curator interface. Assign curator cost to every object in the game.
Triggered when a unit, it is assigned to, respawns. This EH does not work as one would expect MP EH should work like.
This is the primary method that a mission designer can use to limit the objects a curator can place.<br>
It is only triggered on one machine where the unit it was assigned to is [[Multiplayer Scripting#Locality|local]].
{{Feature|informative|See {{Link|Curator#Manual Assigning}}.}}
The only difference between '''Respawn''' and '''MPRespawn''' is that '''MPRespawn''' can be assigned from anywhere while '''Respawn''' requires the unit to be local.<br><br>
MPRespawn EH expects the EH code to return array in format of [[Position]], which will be used to place respawned unit at desired coordinates.<br>
For example: <sqf inline>player addMPEventHandler ["MPRespawn", { [1234, 1234, 0] }];</sqf> will place player at [1234,1234,0] immediately on respawn.
 


<sqf>
<sqf>
this addMPEventHandler ["MPRespawn", {
this addEventHandler ["CuratorObjectRegistered", {
params ["_unit", "_corpse"];
params ["_curator", "_input"];
}];
}];
</sqf>
</sqf>


* unit: [[Object]] - object the event handler is assigned to
* curator: [[Object]]
* corpse: [[Object]] - object the event handler was assigned to, aka the corpse/unit player was previously controlling.
* input: [[Array]] of [[String]]s - all [[Arma 3: Assets|CfgVehicles]] classes
{{ConfigPage|end}}


=== CuratorObjectSelectionChanged ===


== Mission Event Handlers ==
{{Icon|localArgument|32}}<br>
Triggered when an object is selected in curator interface.


Mission Event Handlers are specific EHs that are anchored to the running mission and automatically removed when mission is over.
<sqf>
this addEventHandler ["CuratorObjectSelectionChanged", {
params ["_curator", "_entity"];
}];
</sqf>


Commands:
* curator: [[Object]]
* [[addMissionEventHandler]]
* entity: [[Object]]
* [[removeMissionEventHandler]]


{{Feature | informative | See [[Arma 3: Mission Event Handlers]].}}
=== CuratorPinged ===


{{Icon|localArgument|32}}<br>
Triggered when a player pings his curator(s) by pressing the ''Zeus'' key.


{{ArgTitle|2|UserAction Event Handlers|{{GVI|arma3|2.06}}}}
UserAction Event Handlers are events that trigger on user action.
Commands:
* [[addUserActionEventHandler]]
* [[removeUserActionEventHandler]]
{{Feature | informative | See [[Arma 3: Modded Keybinding]].}}
{{ConfigPage|start}}
{{ConfigPage|abc}}
==== Activate ====
<sqf>
<sqf>
addUserActionEventHandler ["KeyName", "Activate", {
this addEventHandler ["CuratorPinged", {
params ["_activated"];
params ["_curator", "_player"];
}];
}];
</sqf>
</sqf>


* _activated: [[Boolean]] - always returns [[true]]
* curator: [[Object]]
* player: [[Object]]
 
{{ArgTitle|3|CuratorSelectionPresetLoaded|{{GVI|arma3|2.14}}}}
 
{{Icon|localArgument|32}}<br>
Triggered when a selection preset is loaded using the respective number key or through script.


==== Deactivate ====
<sqf>
<sqf>
addUserActionEventHandler ["KeyName", "Deactivate", {
this addEventHandler ["CuratorSelectionPresetLoaded", {
params ["_activated"];
params ["_curator", "_numkey"];
}];
}];
</sqf>
</sqf>


* _activated: [[Boolean]] - always returns [[false]]
* curator: [[Object]]
* numkey: [[Number]]
 
{{ArgTitle|3|CuratorSelectionPresetSaved|{{GVI|arma3|2.14}}}}
 
{{Icon|localArgument|32}}<br>
Triggered when a selection preset is saved using the respective CTRL + number key or set through script.


==== Analog ====
<sqf>
<sqf>
addUserActionEventHandler ["KeyName", "Analog", {
this addEventHandler ["CuratorSelectionPresetSaved", {
params ["_value"];
params ["_curator", "_numkey"];
}];
}];
</sqf>
</sqf>


* _value: [[Number]] - input device's analog value
* curator: [[Object]]
{{ConfigPage|end}}
* numkey: [[Number]]


=== CuratorWaypointDeleted ===


{{ArgTitle|2|Projectile Event Handlers|{{GVI|arma3|2.10}}}}
{{Icon|localArgument|32}}<br>
 
Triggered when a waypoint is deleted in curator interface.
Commands:
* [[addEventHandler]]
* [[removeEventHandler]]


{{ConfigPage|start}}
{{ConfigPage|abc}}
==== Explode ====
<sqf>
<sqf>
_projectile addEventHandler ["Explode", {
this addEventHandler ["CuratorWaypointDeleted", {
params ["_projectile", "_pos", "_velocity"];
params ["_curator", "_waypoint"];
}];
}];
</sqf>
</sqf>


* projectile: [[Object]]
* curator: [[Object]]
* pos: [[Array]] format [[Position#PositionASL|PositionASL]]
* waypoint: [[Array]]
* velocity: [[Array]] format [[Vector3D]]


==== Deflected ====
=== CuratorWaypointDoubleClicked ===
<sqf>
 
_projectile addEventHandler ["Deflected", {
{{Icon|localArgument|32}}<br>
params ["_projectile", "_pos", "_velocity", "_hitObject"];
Triggered when a waypoint is double-clicked on in curator interface.
}];
</sqf>
* projectile: [[Object]]
* pos: [[Array]] format [[Position#PositionASL|PositionASL]]
* velocity: [[Array]] format [[Vector3D]]
* hitObject: [[Object]] - the object that deflected the projectile


==== SubmunitionCreated ====
This event fires as many times as submunitions are created.
<sqf>
<sqf>
_projectile addEventHandler ["SubmunitionCreated", {
this addEventHandler ["CuratorWaypointDoubleClicked", {
params ["_projectile", "_submunitionProjectile", "_pos", "_velocity"];
params ["_curator", "_waypoint"];
}];
}];
</sqf>
</sqf>


* projectile: [[Object]]
* curator: [[Object]]
* subMunitionProjectile: [[Object]]
* waypoint: [[Array]]
* pos: [[Array]] format [[Position#PositionASL|PositionASL]]
 
* velocity: [[Array]] format [[Vector3D]]
=== CuratorWaypointEdited ===
 
{{Icon|localArgument|32}}<br>
Triggered when a waypoint is moved in curator interface.


==== HitExplosion ====
<sqf>
<sqf>
_projectile addEventHandler ["HitExplosion", {
this addEventHandler ["CuratorWaypointEdited", {
params ["_projectile", "_hitEntity", "_projectileOwner", "_hitThings"];
params ["_curator", "_waypoint"];
}];
}];
</sqf>
</sqf>


* projectile: [[Object]]
* curator: [[Object]]
* hitEntity: [[Object]]
* waypoint: [[Array]]
* projectileOwner: [[Object]]
* hitThings: [[Array]] of [[Object]]s


==== HitPart ====
=== CuratorWaypointPlaced ===
<sqf>
_projectile addEventHandler ["HitPart", {
params ["_projectile", "_hitEntity", "_projectileOwner", "_pos", "_velocity", "_normal", "_component", "_radius" ,"_surfaceType"];
}];
</sqf>


* projectile: [[Object]]
{{Icon|localArgument|32}}<br>
* hitEntity: [[Object]]
Triggered when new waypoint is placed in curator interface.
* projectileOwner: [[Object]]
* pos: [[Array]] format [[Position#PositionASL|PositionASL]]
* velocity: [[Array]] format [[Vector3D]]
* normal: [[Array]] format [[Vector3D]]
* component: [[String]]
* radius: [[Number]] - radius (size) of component hit
* surfaceType: [[String]]
 
==== Init ====
Triggered whenever a projectile is created. Cannot be used in scripts, only inside class Eventhandlers in config.
<syntaxhighlight lang="cpp">init = "params ['_projectile'];";</syntaxhighlight>
<sqf>params ["_projectile"];</sqf>
* projectile: [[Object]] - object the event handler is assigned to


==== Deleted ====
<sqf>
<sqf>
_projectile addEventHandler ["Deleted", {
this addEventHandler ["CuratorWaypointPlaced", {
params ["_projectile"];
params ["_curator", "_group", "_waypointID"];
}];
}];
</sqf>
</sqf>


* projectile: [[Object]]
* curator: [[Object]]
{{ConfigPage|end}}
* group: [[Group]]
* waypointID: [[Number]]


=== CuratorWaypointSelectionChanged ===


{{ArgTitle|2|Group Event Handlers|{{GVI|arma3|2.10}}}}
{{Icon|localArgument|32}}<br>
 
Triggered when a waypoint is selected in curator interface.
Commands:
* [[addEventHandler]]
* [[removeEventHandler]]


{{ConfigPage|start}}
{{ConfigPage|abc}}
==== UnitJoined ====
<sqf>
<sqf>
_group addEventHandler ["UnitJoined", {
this addEventHandler ["CuratorWaypointSelectionChanged", {
params ["_group", "_newUnit"];
params ["_curator", "_waypoint"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* curator: [[Object]]
* newUnit: [[Object]]
* waypoint: [[Array]]
 
{{ArgTitle|2|UserAction Event Handlers|{{GVI|arma3|2.06}}}}
 
UserAction Event Handlers are events that trigger on user action.
 
Commands:
* [[addUserActionEventHandler]]
* [[removeUserActionEventHandler]]
{{Feature|informative|See [[Arma 3: Modded Keybinding]].}}
 
=== Activate ===


==== UnitLeft ====
<sqf>
<sqf>
_group addEventHandler ["UnitLeft", {
addUserActionEventHandler ["KeyName", "Activate", {
params ["_group", "_oldUnit"];
params ["_activated"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* activated: [[Boolean]] - always returns [[true]]
* oldUnit: [[Object]]
 
=== Deactivate ===


==== VehicleAdded ====
<sqf>
<sqf>
_group addEventHandler ["VehicleAdded", {
addUserActionEventHandler ["KeyName", "Deactivate", {
params ["_group", "_newVehicle"];
params ["_activated"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* activated: [[Boolean]] - always returns [[false]]
* newVehicle: [[Object]]
 
=== Analog ===


==== VehicleRemoved ====
<sqf>
<sqf>
_group addEventHandler ["VehicleRemoved", {
addUserActionEventHandler ["KeyName", "Analog", {
params ["_group", "_oldVehicle"];
params ["_value"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* value: [[Number]] - input device's analog value
* oldVehicle: [[Object]]
 
{{ArgTitle|2|Projectile Event Handlers|{{GVI|arma3|2.10}}}}
 
Commands:
* [[addEventHandler]]
* [[removeEventHandler]]
* [[removeAllEventHandlers]]
 
=== Deleted ===


==== Empty ====
<sqf>
<sqf>
_group addEventHandler ["Empty", {
_projectile addEventHandler ["Deleted", {
params ["_group"];
params ["_projectile"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* projectile: [[Object]]
 
=== Deflected ===


==== Deleted ====
<sqf>
<sqf>
_group addEventHandler ["Deleted", {
_projectile addEventHandler ["Deflected", {
params ["_group"];
params ["_projectile", "_position", "_velocity", "_hitObject"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* projectile: [[Object]]
* position: [[Array]] format [[Position#PositionASL|PositionASL]]
* velocity: [[Array]] format [[Vector3D]]
* hitObject: [[Object]] - the object that deflected the projectile
 
=== Explode ===
 
{{Icon|localArgument|32}}<br>


==== Local ====
<sqf>
<sqf>
_group addEventHandler ["Local", {
_projectile addEventHandler ["Explode", {
params ["_group"];
params ["_projectile", "_position", "_velocity"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* projectile: [[Object]]
* position: [[Array]] format [[Position#PositionASL|PositionASL]]
* velocity: [[Array]] format [[Vector3D]]
 
=== HitExplosion ===


==== CombatModeChanged ====
<sqf>
<sqf>
_group addEventHandler ["CombatModeChanged", {
_projectile addEventHandler ["HitExplosion", {
params ["_group", "_newMode"];
params ["_projectile", "_hitEntity", "_projectileOwner", "_hitSelections", "_instigator"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* projectile: [[Object]]
* newMode: [[String]] - see [[Combat Modes]]
* hitEntity: [[Object]]
* projectileOwner: [[Object]]
* hitSelections: [[Array]] of [[Array]]s - same list of FireGeometry components that [[#HitPart|entity HitPart]] gets but only contains:
** position: [[Array]] format [[Position#PositionASL|PositionASL]] - position of impact
** vector: [[Array]] format [[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
** selection: [[String]] - named selection of the object that was hit, in the FireGeometry LOD.
** radius: [[Number]] - radius (size) of component hit
** surface: [[String]] - surface type struck
* {{GVI|arma3|2.18}} instigator: [[Object]] - shot instigator
 
=== HitPart ===
 
Triggered when the projectile hits any surface.


==== CommandChanged ====
<sqf>
<sqf>
_group addEventHandler ["CommandChanged", {
_projectile addEventHandler ["HitPart", {
params ["_group", "_newCommand"];
params ["_projectile", "_hitEntity", "_projectileOwner", "_pos", "_velocity", "_normal", "_components", "_radius" ,"_surfaceType", "_instigator"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* projectile: [[Object]]
* newCommand: [[String]], can be one of: <spoiler>
* hitEntity: [[Object]]
{|
* projectileOwner: [[Object]]
| "NO CMD" || NoCommand
* pos: [[Array]] format [[Position#PositionASL|PositionASL]]
|-
* velocity: [[Array]] format [[Vector3D]]
| "WAIT" || Wait
* normal: [[Array]] format [[Vector3D]]
|-
* components: [[Array]] of [[String]]s - the selections that were hit, in the FireGeometry LOD.
| "ATTACK" || Attack
* radius: [[Number]] - radius (size) of the hitPoint
|-
* surfaceType: [[String]]
| "Suppress" || Suppress
* {{GVI|arma3|2.18}} instigator: [[Object]] - shot instigator
|-
 
| "HIDE" || Hide
{{Feature|important|Only triggers for direct hits and not splash damage, unlike [[#HitPart|entity HitPart]]. For splash damage, use [[#HitExplosion|HitExplosion]].}}
|-
 
| "MOVE" || Move
=== Init ===
|-
 
| "HOOK CARGO" || HookCargo
Triggered whenever a projectile is created. Cannot be used in scripts, only inside class Eventhandlers in config.
|-
<syntaxhighlight lang="cpp">init = "params ['_projectile'];";</syntaxhighlight>
| "UNHOOK CARGO" || UnhookCargo
 
|-
<sqf>params ["_projectile"];</sqf>
| "VIV GETIN" || ViVGetIn
 
|-
* projectile: [[Object]] - object the event handler is assigned to
| "VIV GETOUT" || ViVGetOut
 
|-
{{ArgTitle|3|MineActivated|{{GVI|arma3|2.14}}}}
| "VIV UNLOAD" || ViVUnload
 
|-
{{Icon|localArgument|32}}
| "HEAL" || Heal
{{Icon|localEffect|32}}<br>
|-
 
| "REPAIR" || Repair
<sqf>
|-
_projectile addEventHandler ["MineActivated", {
| "REFUEL" || Refuel
params ["_projectile", "_isActive"];
|-
}];
| "REARM" || Rearm
</sqf>
|-
 
| "SUPPORT" || Support
* projectile: [[Object]]
|-
* isActive: [[Boolean]] - new active state of the mine
| "JOIN" || Join
 
|-
=== Penetrated ===
| "GET IN" || GetIn
 
|-
This event fires as many times as the projectile penetrates a surface.
| "FIRE" || Fire
 
|-
<sqf>
| "GET OUT" || GetOut
_projectile addEventHandler ["Penetrated", {
|-
params ["_projectile", "_hitObject", "_surfaceType", "_entryPoint", "_exitPoint", "_exitVector"];
| "STOP" || Stop
}];
|-
</sqf>
| "EXPECT" || Expect
 
* projectile: [[Object]]
* hitObject: [[Object]]
* surfaceType: [[String]] - see [[surfaceType]]
* entryPoint: [[Array]] format [[Position#PositionASL|PositionASL]] - the projectile's entry point
* exitPoint: [[Array]] format [[Position#PositionASL|PositionASL]] - the projectile's exit point
* exitVector: [[Array]] format [[Vector3D]] - speed/angle exit vector (see [[vectorMagnitude]] to obtain the speed, in metre per second)
 
=== SubmunitionCreated ===
 
This event fires as many times as submunitions are created.
 
<sqf>
_projectile addEventHandler ["SubmunitionCreated", {
params ["_projectile", "_submunitionProjectile", "_position", "_velocity"];
}];
</sqf>
 
* projectile: [[Object]]
* subMunitionProjectile: [[Object]]
* position: [[Array]] format [[Position#PositionASL|PositionASL]]
* velocity: [[Array]] format [[Vector3D]]
 
{{ArgTitle|2|Group Event Handlers|{{GVI|arma3|2.10}}}}
 
Commands:
* [[addEventHandler]]
* [[removeEventHandler]]
* [[removeAllEventHandlers]]
 
=== CombatModeChanged ===
 
Triggers when the group's '''[[AI Behaviour|behaviour]]''' changes (see [[behaviour]], [[setBehaviour]])
 
<sqf>
_group addEventHandler ["CombatModeChanged", {
params ["_group", "_newMode"];
}];
</sqf>
 
* group: [[Group]]
* newMode: [[String]] - see [[AI Behaviour]] ('''not''' [[Combat Modes]]!)
 
=== CommandChanged ===
 
<sqf>
_group addEventHandler ["CommandChanged", {
params ["_group", "_newCommand"];
}];
</sqf>
 
* group: [[Group]]
* newCommand: [[String]], can be one of: <spoiler>
{|
| "NO CMD" || NoCommand
|-
|-
| "ACTION" || Action
| "WAIT" || Wait
|-
|-
| "SCRIPTED" || Scripted
| "ATTACK" || Attack
|-
|-
| "DISMISS" || Dismiss
| "Suppress" || Suppress
|-
|-
| "HEAL SOLDIER" || HealSoldier
| "HIDE" || Hide
|-
|-
| "PATCH SOLDIER" || PatchSoldier
| "MOVE" || Move
|-
|-
| "FIRST AID" || FirstAid
| "HOOK CARGO" || HookCargo
|-
|-
| "HEAL SELF" || HealSoldierSelf
| "UNHOOK CARGO" || UnhookCargo
|-
|-
| "ATTACK AND FIRE" || AttackAndFire
| "VIV GETIN" || ViVGetIn
|-
|-
| "CARRY SOLDIER" || CarrySoldier
| "VIV GETOUT" || ViVGetOut
|-
|-
| "DROP CARRIED" || DropCarried
| "VIV UNLOAD" || ViVUnload
|-
|-
| "TAKE BAG" || TakeBag
| "HEAL" || Heal
|-
|-
| "ASSEMBLE" || Assemble
| "REPAIR" || Repair
|-
|-
| "DISASSEMBLE" || DisAssemble
| "REFUEL" || Refuel
|-
|-
| "DROP BAG" || DropBag
| "REARM" || Rearm
|-
|-
| "OPEN BAG" || OpenBag
| "SUPPORT" || Support
|-
|-
| "IRLASER ON" || IRLaserOn
| "JOIN" || Join
|-
|-
| "IRLASER OFF" || IRLaserOff
| "GET IN" || GetIn
|-
|-
| "GUN LIGHT ON" || GunLightOn
| "FIRE" || Fire
|-
| "GET OUT" || GetOut
|-
|-
| "GUN LIGHT OFF" || GunLightOff
| "STOP" || Stop
|-
|-
| "FIRE AT POSITION" || FireAtPosition
| "EXPECT" || Expect
|-
|-
| "REPAIR VEHICLE" || RepairVehicle
| "ACTION" || Action
|-
|-
| "OPEN PARA" || OpenParachute
| "SCRIPTED" || Scripted
|-
|-
| "KEEP DEPTH LEADER" || KeepDepthLeader
| "DISMISS" || Dismiss
|-
|-
| "KEEP DEPTH UND SURF" || KeepDepthUnderSurface
| "HEAL SOLDIER" || HealSoldier
|-
|-
| "KEEP DEPTH ABV SURF" || KeepDepthAboveSurface
| "PATCH SOLDIER" || PatchSoldier
|-
|-
| "KEEP DEPTH BOTTOM" || KeepDepthBottom
| "FIRST AID" || FirstAid
|-
|-
| "PUT IN" || PutIn
| "HEAL SELF" || HealSoldierSelf
|-
|-
| "UNLOAD FROM" || UnloadFrom
| "ATTACK AND FIRE" || AttackAndFire
|-
|-
| "USE CONTAINER MAGAZINE" || UseContainerMagazine
| "CARRY SOLDIER" || CarrySoldier
|-
|-
| "ACTIVATE MINE" || ActivateMine
| "DROP CARRIED" || DropCarried
|-
|-
| "DISABLE MINE" || DisableMine
| "TAKE BAG" || TakeBag
|}
|-
</spoiler>
| "ASSEMBLE" || Assemble
 
|-
==== FormationChanged ====
| "DISASSEMBLE" || DisAssemble
<sqf>
|-
_group addEventHandler ["FormationChanged", {
| "DROP BAG" || DropBag
params ["_group", "_newFormation"];
|-
}];
| "OPEN BAG" || OpenBag
</sqf>
|-
 
| "IRLASER ON" || IRLaserOn
* group: [[Group]]
|-
* newFormation: [[String]] - see [[setFormation]]
| "IRLASER OFF" || IRLaserOff
 
|-
==== SpeedModeChanged ====
| "GUN LIGHT ON" || GunLightOn
<sqf>
|-
_group addEventHandler ["SpeedModeChanged", {
| "GUN LIGHT OFF" || GunLightOff
params ["_group", "_newSpeedMode"];
|-
}];
| "FIRE AT POSITION" || FireAtPosition
</sqf>
|-
| "REPAIR VEHICLE" || RepairVehicle
|-
| "OPEN PARA" || OpenParachute
|-
| "KEEP DEPTH LEADER" || KeepDepthLeader
|-
| "KEEP DEPTH UND SURF" || KeepDepthUnderSurface
|-
| "KEEP DEPTH ABV SURF" || KeepDepthAboveSurface
|-
| "KEEP DEPTH BOTTOM" || KeepDepthBottom
|-
| "PUT IN" || PutIn
|-
| "UNLOAD FROM" || UnloadFrom
|-
| "USE CONTAINER MAGAZINE" || UseContainerMagazine
|-
| "ACTIVATE MINE" || ActivateMine
|-
| "DISABLE MINE" || DisableMine
|}
</spoiler>
 
=== Deleted ===


* group: [[Group]]
* newSpeedMode: [[String]] - see [[setSpeedMode]]
==== EnableAttackChanged ====
<sqf>
<sqf>
_group addEventHandler ["EnableAttackChanged", {
_group addEventHandler ["Deleted", {
params ["_group", "_attackEnabled"];
params ["_group"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* group: [[Group]]
* attackEnabled: [[Boolean]]


==== LeaderChanged ====
=== Empty ===
 
<sqf>
<sqf>
_group addEventHandler ["LeaderChanged", {
_group addEventHandler ["Empty", {
params ["_group", "_newLeader"];
params ["_group"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* group: [[Group]]
* newLeader: [[Object]]


==== GroupIdChanged ====
=== EnableAttackChanged ===
 
<sqf>
<sqf>
_group addEventHandler ["GroupIdChanged", {
_group addEventHandler ["EnableAttackChanged", {
params ["_group", "_newGroupId"];
params ["_group", "_attackEnabled"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* group: [[Group]]
* newGroupId: [[String]]
* attackEnabled: [[Boolean]]
 
=== EnemyDetected ===


==== KnowsAboutChanged ====
<sqf>
<sqf>
_group addEventHandler ["KnowsAboutChanged", {
_group addEventHandler ["EnemyDetected", {
params ["_group", "_targetUnit", "_newKnowsAbout", "_oldKnowsAbout"];
params ["_group", "_newTarget"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* group: [[Group]]
* targetUnit: [[Object]]
* newTarget: [[Object]]
* newKnowsAbout: [[Number]]
* oldKnowsAbout: [[Number]]


==== WaypointComplete ====
=== Fleeing ===
<sqf>
_group addEventHandler ["WaypointComplete", {
params ["_group", "_waypointIndex"];
}];
</sqf>
 
* group: [[Group]]
* waypointIndex: [[Number]]


==== Fleeing ====
<sqf>
<sqf>
_group addEventHandler ["Fleeing", {
_group addEventHandler ["Fleeing", {
Line 2,001: Line 2,318:
* fleeingNow: [[Boolean]]
* fleeingNow: [[Boolean]]


==== EnemyDetected ====
=== FormationChanged ===
 
<sqf>
<sqf>
_group addEventHandler ["EnemyDetected", {
_group addEventHandler ["FormationChanged", {
params ["_group", "_newTarget"];
params ["_group", "_newFormation"];
}];
}];
</sqf>
</sqf>


* group: [[Group]]
* group: [[Group]]
* newTarget: [[Object]]
* newFormation: [[String]] - see [[setFormation]]
{{ConfigPage|end}}


=== GroupIdChanged ===


== Player's UI Event Handlers ==
<sqf>
_group addEventHandler ["GroupIdChanged", {
params ["_group", "_newGroupId"];
}];
</sqf>


In Game UI Event Handlers trigger when user scrolls or activates in game action menu.<br>
* group: [[Group]]
The following mission EHs are available in Arma 3:
* newGroupId: [[String]]
* [[Arma_3: Event Handlers/inGameUISetEventHandler#PrevAction|PrevAction]] - Action menu scroll up event
* [[Arma_3: Event Handlers/inGameUISetEventHandler#Action|Action]] - Action menu action event
* [[Arma_3: Event Handlers/inGameUISetEventHandler#NextAction|NextAction]] - Action menu scroll down event


{{Feature | important | Only one event of each kind can exist, adding another will overwrite the existing one.}}
=== KnowsAboutChanged ===


Commands:
<sqf>
* [[inGameUISetEventHandler]]
_group addEventHandler ["KnowsAboutChanged", {
{{Feature|informative|See {{Link|Arma 3: Event Handlers/inGameUISetEventHandler}}.}}
params ["_group", "_targetUnit", "_newKnowsAbout", "_oldKnowsAbout"];
}];
</sqf>


* group: [[Group]]
* targetUnit: [[Object]]
* newKnowsAbout: [[Number]]
* oldKnowsAbout: [[Number]]


== UI Event Handlers (Displays and Controls) ==
=== LeaderChanged ===


Commands:
<sqf>
* [[ctrlAddEventHandler]]
_group addEventHandler ["LeaderChanged", {
* [[ctrlRemoveEventHandler]]
params ["_group", "_newLeader"];
* [[ctrlRemoveAllEventHandlers]]
}];
* [[displayAddEventHandler]]
</sqf>
* [[displayRemoveEventHandler]]
 
* [[displayRemoveAllEventHandlers]]
* group: [[Group]]
{{Feature|informative|See [[User Interface Event Handlers]].}}
* newLeader: [[Object]]


=== Local ===


== Music Event Handlers ==
<sqf>
_group addEventHandler ["Local", {
params ["_group", "_isLocal"];
}];
</sqf>


Music event handler, always executed on the computer where it was added.
* group: [[Group]]


Commands:
=== SpeedModeChanged ===
* [[setMusicEventHandler]]
 
* [[addMusicEventHandler]]
<sqf>
* [[removeMusicEventHandler]]
_group addEventHandler ["SpeedModeChanged", {
* [[removeAllMusicEventHandlers]]
params ["_group", "_newSpeedMode"];
}];
</sqf>
 
* group: [[Group]]
* newSpeedMode: [[String]] - see [[setSpeedMode]]
 
=== UnitJoined ===


{{ConfigPage|start}}
<sqf>
{{ConfigPage|abc}}
_group addEventHandler ["UnitJoined", {
{{ArgTitle|4|MusicStart|{{GVI|arma3|0.50}}}}
params ["_group", "_newUnit"];
Triggers when [[Description.ext#cfgMusic|CfgMusic]] sound starts playing, after being executed with [[playMusic]] command.
}];
</sqf>


This event handler needs to be added with [[addMusicEventHandler]] command and removed with [[removeMusicEventHandler]].
* group: [[Group]]
* className: [[String]] - [[Description.ext#Music|CfgMusic]] class name of currently playing sound.
* newUnit: [[Object]]
* handlerID: [[Number]] - EH id returned by [[addMusicEventHandler]].


{{ArgTitle|3|UnitKilled|{{GVI|arma3|2.18}}}}


{{ArgTitle|4|MusicStop|{{GVI|arma3|0.50}}}}
{{Icon|localArgument|32}}<br>
Triggers when [[Description.ext#cfgMusic|CfgMusic]] sound finished playing, after being executed with [[playMusic]] command.
Triggered when a unit in the group is killed.
Note that EH will not be triggered if you force stop the music with [[playMusic]] "".


This event handler needs to be added with [[addMusicEventHandler]] command and removed with [[removeMusicEventHandler]].
<sqf>
* className: [[String]] - [[Description.ext#Music|CfgMusic]] class name of currently played sound.
_group addEventHandler ["UnitKilled", {
* handlerID: [[Number]] - EH id returned by [[addMusicEventHandler]].
params ["_group", "_unit", "_killer", "_instigator", "_useEffects"];
{{ConfigPage|end}}
}];
</sqf>


* group: [[Group]] - the group the event handler is assigned to
* unit: [[Object]] - the unit that was killed
* killer: [[Object]] - the object that killed the unit. Contains the unit itself in case of collisions.
* instigator: [[Object]] - the person who pulled the trigger
* useEffects: [[Boolean]] - same as ''useEffects'' in [[setDamage]] alt syntax


== Eden Editor ==
=== UnitLeft ===


Commands:
<sqf>
* [[add3DENEventHandler]]
_group addEventHandler ["UnitLeft", {
* [[remove3DENEventHandler]]
params ["_group", "_oldUnit"];
}];
</sqf>
 
* group: [[Group]]
* oldUnit: [[Object]]
 
=== VehicleAdded ===
 
<sqf>
_group addEventHandler ["VehicleAdded", {
params ["_group", "_newVehicle"];
}];
</sqf>
 
* group: [[Group]]
* newVehicle: [[Object]]
 
=== VehicleRemoved ===
 
<sqf>
_group addEventHandler ["VehicleRemoved", {
params ["_group", "_oldVehicle"];
}];
</sqf>
 
* group: [[Group]]
* oldVehicle: [[Object]]
 
=== WaypointComplete ===
 
<sqf>
_group addEventHandler ["WaypointComplete", {
params ["_group", "_waypointIndex"];
}];
</sqf>
 
* group: [[Group]]
* waypointIndex: [[Number]]
 
 
== Game UI Event Handlers ==
 
In Game UI Event Handlers trigger when user scrolls or activates in game action menu.<br>
The following mission EHs are available in {{arma3}}:
* [[Arma 3: Event Handlers/inGameUISetEventHandler#PrevAction|PrevAction]] - action menu scroll up event
* [[Arma 3: Event Handlers/inGameUISetEventHandler#Action|Action]] - action menu action event
* [[Arma 3: Event Handlers/inGameUISetEventHandler#NextAction|NextAction]] - action menu scroll down event
 
{{Feature|important|Only one event of each kind can exist, adding another will overwrite the existing one.}}
 
Commands:
* [[inGameUISetEventHandler]]
 
{{Feature|informative|See {{Link|Arma 3: Event Handlers/inGameUISetEventHandler}}.}}
 
 
== Control/Display UI Event Handlers ==
 
Commands:
* [[ctrlAddEventHandler]]
* [[ctrlRemoveEventHandler]]
* [[ctrlRemoveAllEventHandlers]]
* [[displayAddEventHandler]]
* [[displayRemoveEventHandler]]
* [[displayRemoveAllEventHandlers]]
 
{{Feature|informative|See [[User Interface Event Handlers]].}}
 
 
== Music Event Handlers ==
 
Music event handler, always executed on the computer where it was added.
 
{{Feature|informative|Does not apply to [[hasInterface|interface-less]] machines (dedicated server, headless client).}}
 
Commands:
* [[setMusicEventHandler]]
* [[addMusicEventHandler]]
* [[removeMusicEventHandler]]
* [[removeAllMusicEventHandlers]]
 
{{ArgTitle|3|MusicStart|{{GVI|arma3|0.50}}}}
 
Triggers when [[Description.ext#cfgMusic|CfgMusic]] sound starts playing, after being executed with [[playMusic]] command.
 
<sqf>
addMusicEventHandler ["MusicStart", {
params ["_musicClassname", "_eventHandlerID", "_currentPosition", "_totalLength"];
}];
</sqf>
 
* musicClassName: [[String]] - [[Description.ext#Music|CfgMusic]] class name of the music that started
* eventHandlerID: [[Number]] - EH id returned by [[addMusicEventHandler]]
* {{GVI|arma3|2.18}} currentPosition: [[Number]] - current playback position in 0...1 range (see also: [[getMusicPlayedTime]])
* {{GVI|arma3|2.18}} totalLength: [[Number]] - track total length in seconds
 
{{ArgTitle|3|MusicStop|{{GVI|arma3|0.50}}}}
 
Triggers when [[Description.ext#cfgMusic|CfgMusic]] sound finished playing, after being executed with [[playMusic]] command.<br>
{{GVI|arma3|2.14|size= 0.75}} <sqf inline>playMusic ""</sqf> triggers this event if a music is currently playing.
 
<sqf>
addMusicEventHandler ["MusicStop", {
params ["_musicClassname", "_eventHandlerID", "_currentPosition", "_totalLength"];
}];
</sqf>
 
* musicClassName: [[String]] - [[Description.ext#Music|CfgMusic]] class name of the music that stopped
* eventHandlerID: [[Number]] - EH id returned by [[addMusicEventHandler]]
* {{GVI|arma3|2.18}} currentPosition: [[Number]] - current playback position in 0...1 range (see also: [[getMusicPlayedTime]])
* {{GVI|arma3|2.18}} totalLength: [[Number]] - track total length in seconds
 
 
== Eden Editor ==
 
Commands:
* [[add3DENEventHandler]]
* [[remove3DENEventHandler]]
* [[removeAll3DENEventHandlers]]
* [[removeAll3DENEventHandlers]]
{{Feature|informative|See also:
 
* [[Arma 3: Event Handlers: Eden Editor]]
{{Feature|informative|
* its sub-category [[Arma 3: Event Handlers: Eden Editor#Object Event Handlers|Object Event Handlers]]
See also:
* [[Eden Editor]]
* [[Arma 3: Event Handlers: Eden Editor]]
}}
* its sub-category [[Arma 3: Event Handlers: Eden Editor#Object Event Handlers|Object Event Handlers]]
 
* [[:Category:Eden Editor|Eden Editor]]
 
}}
== Public Variable Broadcast Event ==
 
 
 
Commands:
== Public Variable Broadcast Event ==
* [[addPublicVariableEventHandler]]
 
 
Commands:
Triggers when [[missionNamespace]] variable EH is associated with is sent over network via [[publicVariable]], [[publicVariableServer]] or [[publicVariableClient]] commands.
* [[addPublicVariableEventHandler]]
{{Feature | Informative | Unlike with other types of EHs, there is no way of removing added public variable event handler}}
 
 
Triggers when [[missionNamespace]] variable EH is associated with is sent over network via [[publicVariable]], [[publicVariableServer]] or [[publicVariableClient]] commands.
== Weapon Config Muzzle Events ==
{{Feature|informative|Unlike with other types of EHs, there is no way of removing added public variable event handler}}
There are 3 event handlers that could be set on weapon in config, "Fired" - when muzzle fired, "Reload" - before muzzle is reloaded, "Reloaded" - after muzzle is reloaded.
 
<syntaxhighlight lang="cpp">
 
class CfgWeapons
== Weapon Muzzle Config Events ==
{
 
 
There are three event handlers that can be set on weapon in config:
class RifleCore;
* "Fired" - when muzzle fired
class Rifle: RifleCore
* "Reload" - before muzzle is reloaded
{
* "Reloaded" - after muzzle is reloaded
class EventHandlers
<syntaxhighlight lang="cpp">
{
class CfgWeapons
fired = "systemchat format['fired EH output: %1 [time: %2]', _this, time]";
{
reload = "systemchat format['reload EH output: %1 [time: %2]', _this, time]";
class RifleCore;
reloaded = "systemchat format['reloaded EH output: %1 [time: %2]', _this, time]";
class TAG_Rifle : RifleCore
};
{
};
class EventHandlers
};
{
</syntaxhighlight>
fired = "systemChat format ['fired weapon EH output: %1 [time: %2]', _this, time]";
reload = "systemChat format ['reload weapon EH output: %1 [time: %2]', _this, time]";
reloaded = "systemChat format ['reloaded weapon EH output: %1 [time: %2]', _this, time]";
};
};
};
</syntaxhighlight>
 
 
== Ammo Config Events ==
 
There are three event handlers that can be set on ammo in config:
* "init" - when the ammo is created, by any mean (fired, created, etc). Params: [shot]
* "fired" - when the ammo is fired (legacy). Params: same as in entity EH "Fired".
* "ammoHit" - when the ammo hits anything (can trigger multiple times). Params: [shot, shooter, hitobj, pos, velocity, hitComponents, [hit, indirecthit, indirecthitrange, explosive, name], normal, explode, instigator (since Arma 3 v2.18)]
<syntaxhighlight lang="cpp">
class CfgAmmo
{
class BulletCore;
class TAG_Bullet : BulletCore
{
class EventHandlers
{
init = "systemChat format ['init ammo EH output: %1 [time: %2]', _this, time]";
fired = "systemChat format ['fired ammo EH output: %1 [time: %2]', _this, time]";
ammoHit = "systemChat format ['ammoHit EH output: %1 [time: %2]', _this, time]";
};
};
};
</syntaxhighlight>
 
 
== BI Scripted Events ==
 
Commands:
* [[BIS_fnc_addScriptedEventHandler]]
* [[BIS_fnc_removeScriptedEventHandler]]
* [[BIS_fnc_removeAllScriptedEventHandlers]]
* [[BIS_fnc_callScriptedEventHandler]]




== BI Scripted Events ==
Commands:
* [[BIS_fnc_addScriptedEventHandler]]
* [[BIS_fnc_removeScriptedEventHandler]]
* [[BIS_fnc_removeAllScriptedEventHandlers]]
* [[BIS_fnc_callScriptedEventHandler]]
{{Feature|informative|See also [[Arma 3: Scripted Event Handlers]].}}
{{Feature|informative|See also [[Arma 3: Scripted Event Handlers]].}}
{{Sticky|Jump to [[#top|the top]] of the page|bottom}}




[[Category: Event Handlers]]
[[Category: Event Handlers]]

Latest revision as of 12:08, 7 August 2025

An Event Handler (abbreviated to EH) allows you to automatically monitor and then execute custom code upon particular events being triggered.
See also Event Scripts for special event triggered scripts.


Basic Event Handlers

The object-based Event Handler is always executed on the computer where it was added.

Commands:

AnimChanged

GAGlobal
Triggered every time a new animation is started. This EH is only triggered for the 1st animation state in a sequence.

this addEventHandler ["AnimChanged", { params ["_unit", "_anim"]; }];

  • unit: Object - object the event handler is assigned to
  • anim: String - name of the anim that is started

AnimDone

GAGlobal
Triggered every time an animation is finished. Triggered for all animation states in a sequence.

this addEventHandler ["AnimDone", { params ["_unit", "_anim"]; }];

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

AnimStateChanged

GAGlobal
Triggered every time an animation state changes. Triggered for all animation states in a sequence.

this addEventHandler ["AnimStateChanged", { params ["_unit", "_anim"]; }];

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

Assembled

LALocal
Triggers when weapon that is moved out of the world is assembled again. EH should be attached to the entity.

this addEventHandler ["Assembled", { params ["_entity", "_unit", "_primaryBag", "_secondaryBag"]; }];

  • entity: Object - weapon this event is assigned to
  • unit: Object - person who assembled the weapon
  • primaryBag: Object - first backpack object which was entity disassembled into (just before it is deleted)
  • secondaryBag: Object - second backpack object which was entity disassembled into (just before it is deleted)

Attached

Triggered after an object has been attached to another object (see attachTo).

this addEventHandler ["Attached", { params ["_attachedObj", "_parentObj", "_isReattach", "_offset", "_memoryPointIndex", "_followBoneRotation"]; }];

CargoLoaded

GAGlobal
Triggered when a vehicle is loaded into another vehicle (ViV).
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.

this addEventHandler ["CargoLoaded", { params ["_parentVehicle", "_cargoVehicle"]; }];

  • parentVehicle: Object - the transport (parent) vehicle
  • cargoVehicle: Object - the cargo (child) vehicle

CargoUnloaded

GAGlobal
Triggered when a vehicle is unloaded from another vehicle (ViV).
It can be added to either the transport vehicle, or the cargo vehicle, and will fire for both cases.

this addEventHandler ["CargoUnloaded", { params ["_parentVehicle", "_cargoVehicle"]; }];

  • parentVehicle: Object - the transport (parent) vehicle
  • cargoVehicle: Object - the cargo (child) vehicle

ContainerClosed

GAGlobal
Triggers when player finished accessing cargo container. This event handler is similar to InventoryClosed EH, but needs to be assigned to the container rather than the player.
Note: will trigger only for the unit opening container.

this addEventHandler ["ContainerClosed", { params ["_container", "_unit"]; }];

  • container: Object - cargo container.
  • unit: Object - unit who accessed the container

ContainerOpened

GAGlobal
Triggers when cargo container is accessed by player. This event handler is similar to InventoryOpened EH, but needs to be assigned to the container rather than the player and cannot be overridden.
Note: will trigger only for the unit opening container.

this addEventHandler ["ContainerOpened", { params ["_container", "_unit"]; }];

  • container: Object - cargo container
  • unit: Object - unit who accessed the container

ControlsShifted

GAGlobalLELocal
Triggers when control of a vehicle is shifted (pilot->co-pilot, co-pilot->pilot), usually when user performs an action such as TakeVehicleControl, SuspendVehicleControl, UnlockVehicleControl, LockVehicleControl, or when enableCopilot command is used. This event handler will always fire on the PC where action is triggered as well as where the vehicle is local at the time. When control of the vehicle is shifted, the locality of the vehicle changes to the locality of the new controller. For example, if helicopter is local to the server and co-pilot takes controls, the helicopter changes locality to co-pilot PC. This means that if "ControlsShifted" EH was added on both server and client, "Take Controls" action will trigger EH on both, client and server PC, but subsequent co-pilot "Release Controls" action will trigger only on co-pilot's PC, because vehicle will be local to co-pilot at this point. There is also a slightly better mission version of ControlsShifted event handler.

this addEventHandler ["ControlsShifted", { params ["_vehicle", "_activeCoPilot", "_oldController"]; }];

  • vehicle: Object - vehicle which controls were shifted
  • activeCoPilot: Object - co-pilot unit which controls vehicle after this event. objNull if co-pilot is not controlling the vehicle
  • oldController: Object - unit who controlled vehicle before this event

Dammaged

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

Notes:

  • The typo is "intentional": it is Dammaged with two "m".
  • If simultaneous damage occured (e.g. via grenade) EH might be triggered several times.
  • The Dammaged EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.

this addEventHandler ["Dammaged", { params ["_unit", "_hitSelection", "_damage", "_hitPartIndex", "_hitPoint", "_shooter", "_projectile"]; }];

  • unit: Object - object the event handler is assigned to
  • hitSelection: String - name of the selection where the unit was damaged
  • damage: Number - resulting level of damage
  • Arma 3 logo black.png 1.68 hitPartIndex: Number - hit index of the hit selection
  • Arma 3 logo black.png 1.68 hitPoint: String - hit point Cfg name
  • Arma 3 logo black.png 1.70 shooter: Object - shooter reference (to get instigator use getShotParents on projectile)
  • Arma 3 logo black.png 1.70 projectile: Object - the projectile that caused damage

Deleted

GAGlobal
Triggered just before the assigned entity is deleted.

this addEventHandler ["Deleted", { params ["_entity"]; }];

  • entity: Object - object the event handler is assigned to

Detached

Triggered after an object has been detached from its parent object (see detach). Does not fire if the parent object was deleted.

this addEventHandler ["Detached", { params ["_attachedObj", "_parentObj"]; }];

Disassembled

LALocal
Triggers when entity such as weapon/backpack gets disassembled. EH should be attached to the entity.

this addEventHandler ["Disassembled", { params ["_entity", "_primaryBag", "_secondaryBag", "_unit"]; }];

  • entity: Object - weapon this event is assigned to (just before is is moved out of the world)
  • primaryBag: Object - first backpack object which was entity disassembled into
  • secondaryBag: Object - second backpack object which was entity disassembled into
  • Arma 3 logo black.png 2.18 unit: Object - person who disassembled the weapon

Engine

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

Although the event is global, on clients (non-server) and applied to remote vehicles, it will fire only if the vehicle is closer than about 6 km from the camera. Should the vehicle be far away, it will fire as soon as the camera and vehicle are close enough together, alongside the isEngineOn flag change.

this addEventHandler ["Engine", { params ["_vehicle", "_engineState"]; }];

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

EpeContact

GAGlobal
Triggered when object collision (PhysX) is in progress.

this addEventHandler ["EpeContact", { params ["_object1", "_object2", "_selection1", "_selection2", "_force", "_reactVect", "_worldPos"]; }];

  • object1: Object - object with attached handler
  • object2: Object - object which is colliding with object1
  • selection1: String - selection of object1 which is colliding - not in use at this moment, empty string is always returned
  • selection2: String - selection of object2 which is colliding - not in use at this moment, empty string is always returned
  • force: Number - force of collision
  • Arma 3 logo black.png 2.12 reactVect: Array - impact reaction force vector
  • Arma 3 logo black.png 2.12 worldPos: PositionWorld - point of impact in world coordinates

EpeContactEnd

GAGlobal
Triggered when object collision (PhysX) ends.

this addEventHandler ["EpeContactEnd", { params ["_object1", "_object2", "_selection1", "_selection2", "_force"]; }];

  • object1: Object - object with attached handler
  • object2: Object - object which is colliding with object1
  • selection1: String - selection of object1 which is colliding - not in use at this moment, empty string is always returned
  • selection2: String - selection of object2 which is colliding - not in use at this moment, empty string is always returned
  • force: Number - force of collision

EpeContactStart

GAGlobal
Triggered when object collision (PhysX) starts.

this addEventHandler ["EpeContactStart", { params ["_object1", "_object2", "_selection1", "_selection2", "_force", "_reactForce", "_worldPos"]; }];

  • object1: Object - object with attached handler
  • object2: Object - object which is colliding with object1
  • select1: String - selection of object1 which is colliding - not in use at this moment, empty string is always returned
  • select2: String - selection of object2 which is colliding - not in use at this moment, empty string is always returned
  • force: Number - force of collision
  • Arma 3 logo black.png 2.12 reactForce: Array - impact reaction force vector
  • Arma 3 logo black.png 2.12 worldPos: PositionWorld - point of impact in world coordinates

Explosion

GAGlobal
Triggered when a vehicle or unit is damaged by a nearby explosion. It can be assigned to a remote unit or vehicle but will only fire on the PC where EH is added and explosion is local, i.e. it really needs to be added on every PC and JIP and will fire only where the explosion is originated.

this addEventHandler ["Explosion", { params ["_vehicle", "_damage", "_explosionSource"]; }];

  • vehicle: Object - object the event handler is assigned to
  • damage: Number - damage inflicted to the object
  • Arma 3 logo black.png 2.10 explosionSource: Object - the exploding object (NOT the shooter) - may be objNull in some cases
This event will fire even for tiniest of explosion damage (which appears as 0 damage argument), while entity HitPart could ignore such damage and not fire.

Example of such event would be a tank firing AP round and hitting ground a meter away from the vehicle, it does not produce an explosion yet its indirectHit could still cause tiny amount of damage to weak hit points (car wheels, headlights, etc.).

In such case you might not get any HitPart event fires, get some HandleDamage events if target is local, and get this Explosion event.

Fired

GAGlobal
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. When "Manual Fire" is used, the gunner is objNull if gunner is not present or the gunner is not the one who fires. To check if "Manual Fire" is on, use isManualFire. The actual shot instigator could be retrieved with getShotParents command.

Special multiplayer behaviour: When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera.

That range is determined by the fired ammo's highest visibleFire and audibleFire config value.

In case of units, muzzle attachment coefficients are applied too.

this addEventHandler ["Fired", { params ["_unit", "_weapon", "_muzzle", "_mode", "_ammo", "_magazine", "_projectile", "_gunner"]; }];

  • 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 out
  • Arma 3 logo black.png 1.66 gunner: Object - gunner whose weapons are firing.

FiredMan

GAGlobal
Triggered when the unit fires a weapon. This EH must be attached to a soldier and unlike with "Fired" EH, it will fire regardless of whether the soldier is on foot or firing vehicle weapon. For remoteControled unit use "Fired" EH instead.

Special multiplayer behaviour: When added to a remote unit or vehicle, this EH will only fire if said entity is within range of the camera.

That range is determined by the fired ammo's highest visibleFire and audibleFire config value.

In case of units, muzzle attachment coefficients are applied too.

this addEventHandler ["FiredMan", { params ["_unit", "_weapon", "_muzzle", "_mode", "_ammo", "_magazine", "_projectile", "_vehicle"]; }];

  • unit: Object - unit the event handler is assigned to (the instigator)
  • 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 out
  • vehicle: Object - vehicle, if weapon is vehicle weapon, otherwise objNull

FiredNear

GAGlobal
Triggered when a weapon is fired somewhere near the unit or vehicle. It is also triggered if the unit itself is firing.
When "Manual Fire" is used, the gunner is objNull if gunner is not present or the gunner is not the one who fires. To check if "Manual Fire" is on, use isManualFire. The actual shot instigator can be retrieved with getShotParents command.
Arma 3 logo black.png 1.30 Works with thrown weapons (using the "Throw" weapon) like grenades.

this addEventHandler ["FiredNear", { params ["_unit", "_firer", "_distance", "_weapon", "_muzzle", "_mode", "_ammo", "_gunner"]; }];

  • 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
  • Arma 3 logo black.png 1.66 gunner: Object - gunner, whose weapons are fired

Fuel

GAGlobal
Triggered when the vehicle's fuel status changes between non-empty and empty or between empty and non-empty.

this addEventHandler ["Fuel", { params ["_vehicle", "_hasFuel"]; }];

  • vehicle: Object - vehicle the event handler is assigned to
  • hasFuel: Boolean - false when has no fuel, true when has some fuel

Gear

GAGlobal
Triggered when the unit lowers/retracts the landing gear, whether it is a helicopter or a plane. Also triggered for helicopters in landing mode, regardless if they have retractable gear or not.

Not to be confused with InventoryOpened and InventoryClosed events, Gear fires when the landing gear state on an aircraft has changed.

this addEventHandler ["Gear", { params ["_vehicle", "_gearState"]; }];

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

GestureChanged

GAGlobal
Triggered every time a new gesture is played.

this addEventHandler ["GestureChanged", { params ["_unit", "_gesture"]; }];

  • unit: Object - object the event handler is assigned to
  • gesture: String - name of the gesture that has started playing

GestureDone

GAGlobal
Triggered every time a gesture is finished.

this addEventHandler ["GestureDone", { params ["_unit", "_gesture"]; }];

  • unit: Object - object the event handler is assigned to
  • gesture: String - name of the gesture that has been finished

GetIn

GAGlobal
Triggers when a unit enters the vehicle to which this EH has been added. This EH is triggered by moveInXXXX commands and "GetInXXXX" actions, but not upon a seat change within the same vehicle.

In vehicles with multi-turret setup, entering any turret will show "gunner" for position.

this addEventHandler ["GetIn", { params ["_vehicle", "_role", "_unit", "_turret"]; }];

  • vehicle: Object - vehicle the event handler is assigned to
  • role: String - can be either "driver", "gunner", "commander" or "cargo"
  • unit: Object - unit that entered the vehicle
  • Arma 3 logo black.png 1.36 turret: Array - turret path

GetInMan

GAGlobal
Triggers when a unit enters a vehicle. Similar to "GetIn" but must be assigned to a unit and not vehicle. Persistent on respawn if assigned where unit was local. This EH is triggered by moveInXXXX commands and "GetInXXXX" actions.

this addEventHandler ["GetInMan", { params ["_unit", "_role", "_vehicle", "_turret"]; }];

  • unit: Object - unit the event handler is assigned to
  • role: String - can be either "driver", "gunner", "commander" or "cargo"
  • vehicle: Object - vehicle the unit entered
  • turret: Array - turret path

GetOut

GAGlobal
Triggers when a unit gets out from the vehicle to which this EH has been added. This EH is triggered by moveOut, "GetOut" & "Eject" actions, if an alive crew member disconnects or is deleted, but not upon a seat change within the same vehicle.

this addEventHandler ["GetOut", { params ["_vehicle", "_role", "_unit", "_turret", "_isEject"]; }];

  • vehicle: Object - vehicle the event handler is assigned to
  • role: String - can be either "driver", "gunner", "commander" or "cargo"
  • unit: Object - unit that left the vehicle
  • Arma 3 logo black.png 1.36 turret: Array - turret path
  • Arma 3 logo black.png 2.14 isEject: Boolean - true if unit used 'Eject' action

GetOutMan

GAGlobal
Triggers when a unit exits a vehicle. Similar to "GetOut" but must be assigned to a unit and not vehicle. Persistent on respawn if assigned where unit was local. This EH is triggered by moveOut and "GetOut" & "Eject" actions.

this addEventHandler ["GetOutMan", { params ["_unit", "_role", "_vehicle", "_turret", "_isEject"]; }];

  • unit: Object - unit the event handler is assigned to
  • role: String - can be either "driver", "gunner", "commander" or "cargo"
  • vehicle: Object - vehicle that the unit left
  • turret: Array - turret path
  • Arma 3 logo black.png 2.14 isEject: Boolean - true if unit used 'Eject' action

HandleDamage

GAGlobal
Triggers when the unit is damaged and fires for each damaged selection separately Works with all vehicles. This EH can accept a remote unit as argument however it will only fire when the unit is local to the PC this event handler was added on. For example, you can add this event handler to one particular vehicle on every PC. When this vehicle gets hit, only EH on PC where the vehicle is currently local will fire.

If the provided code returns a numeric value, this value will overwrite the default damage of given selection after processing. If no value is returned, the default damage processing will be done - this allows for safe stacking of this event handler. Only the return value of the last added "HandleDamage" EH is considered.

A return value of 0 will make the unit invulnerable if damage is not scripted in other ways (i.e using setDamage and/or setHit for additional damage handling). The return value is the hit zone's absolute damage value, not the damage to be added to it.

Notes:

  • Multiple "HandleDamage" EHs can be added to the same unit. If multiple EHs return damage value for custom damage handling, only last returned value will be considered by the engine.

EHs that do not return value can be safely added after EHs that do return value.

  • You can save the last event as timestamp (diag_tickTime) onto the unit, as well as the current health of the unit/its selections, with setVariable and query it on each "HandleDamage" event with getVariable to define a system how to handle the "HandleDamage" event.
  • "HandleDamage" will continue to trigger even if the unit is already dead.
  • "HandleDamage" is persistent. If you add it to the player object, it will continue to exist after player respawned.
  • "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.
  • Use setMissionOptions to filter out no damage calls or fake head hit.

Additional Celery's explanation (Updated by ShadowRanger for Arma 3).

this addEventHandler ["HandleDamage", { params ["_unit", "_selection", "_damage", "_source", "_projectile", "_hitPartIndex", "_instigator", "_hitPoint", "_directHit", "_context"]; }];

  • unit: Object - object the event handler is assigned to
  • selection: String - name of the selection where the unit was damaged.
    • "" for overall 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 fall damage)
  • Arma 3 logo black.png 1.50 hitPartIndex: Number - hit part index of the hit point, -1 otherwise
  • Arma 3 logo black.png 1.66 instigator: Object - person who pulled the trigger
  • Arma 3 logo black.png 1.68 hitPoint: String - hit point Cfg name
  • Arma 3 logo black.png 2.12 directHit: Boolean - true for direct projectile damage, false for explosion splash damage and all other kinds of damage like fall damage, fire damage, collision damage, etc.
  • Arma 3 logo black.png 2.16 context: Number - some additional context for the event:


0 : TotalDamage - total damage adjusted before iteration through hitpoints
1 : HitPoint - some hit point processed during iteration
2 : LastHitPoint - the last hitpoint from iteration is processed
3 : FakeHeadHit - head hit that is added/adjusted
4 : TotalDamageBeforeBleeding - total damage is adjusted before calculating bleeding

Between an unknown version (confirmed in Arma 3 v1.70) until v1.78 HandleDamage event triggered for every selection of a vehicle, no matter if the section was damaged or not.

HandleHeal

GAGlobal
Triggered when unit starts healing process (player using heal action on self or other unit, scripted action or AI heals after being ordered or on its own). This event handler must be added to the 'injured' (could be added to Init field in editor) and in multiplayer will trigger only on PC where 'healer' is local. If code returns anything but true, engine side healing follows, otherwise healing is aborted.

When AI unit is ordered (or acts at own accord) to heal at a medical vehicle and the event handler returns true, the healing is canceled but AI will try again and again and again. The event handler in this case will fire every second until AI unit is healed by other means.

NOTE: This Event Handler was broken before Arma 3 v2.18.

this addEventHandler ["HandleHeal", { _this spawn { params ["_injured", "_healer", "_isMedic", "_atVehicle", "_action"]; private _damage = damage _injured; if (_injured == _healer) then { waitUntil { damage _injured != _damage }; if (damage _injured < _damage) then { _injured setDamage 0; }; }; }; }];

this addEventHandler ["HandleHeal", { params ["_injured", "_healer", "_isMedic", "_atVehicle", "_action"]; }];

  • injured: Object - unit EH is attached to
  • healer: Object - unit that does the healing (could be the same unit as 'injured')
  • isMedic: Boolean - true when healer is 'Medic'
  • Arma 3 logo black.png 2.18 atVehicle: Object - when healing at medical vehicle, this is the vehicle
  • Arma 3 logo black.png 2.18 action: String - the action that triggered the event handler, for example "SoldierHealSelf"

HandleIdentity

GAGlobal
Triggered whenever an entity is created. Can be used in scripts if EH is added immediately after unit is created in unscheduled environment. Doesn't trigger for editor placed units. Does not work in Multiplayer. If EH scope returns true, the default engine identity application is overridden.

bob = group player createUnit [typeOf player, position player, [], 0, "NONE"]; bob addEventHandler ["HandleIdentity", { params ["_unit"]; hint str _unit; }];

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

HandleRating

LALocal
Triggered when engine adds rating to overall rating of the unit, usually after a kill or a friendly kill. If EH code returns Number, this will override default engine behaviour and the resulting value added will be the one returned by EH code.

this addEventHandler ["HandleRating", { params ["_unit", "_rating"]; }];

  • unit: Object - object the event handler is assigned to
  • rating: Number - rating to be added

HandleScore

GAGlobalSEServer
Triggered when engine adds score to overall score of the unit, usually after a kill. If the EH code returns Nothing or true, the default engine scoreboard update (score, vehicle kills, infantry kills, etc) is applied, if it returns false, the engine update is cancelled. To add or modify score, use addScore and addScoreSide commands. For remote units like players, the event does not persist after respawn, and must be re-added to the new unit.
Note: MP only.

this addEventHandler ["HandleScore", { params ["_unit", "_object", "_score"]; }];

  • unit: Object - object the event handler is assigned to
  • object: Object - object for which score was awarded
  • score: Number - score to be added

Hit

LALocal
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.

this addEventHandler ["Hit", { params ["_unit", "_source", "_damage", "_instigator"]; }];

  • unit: Object - object the event handler is assigned to
  • source: Object - object that caused the damage – contains unit in case of collisions
  • damage: Number - level of damage caused by the hit
  • Arma 3 logo black.png 1.66 instigator: Object - person who pulled the trigger

HitPart

GAGlobal
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 one selection name for the hit component (i.e. a single piece of geometry can be simultaneously part of multiple, overlapping named selections).

While you can add "HitPart" handler to a remote unit, the respective addEventHandler command must be executed on the shooter's PC and will only fire on shooter's PC as well. The event will not fire if the shooter is not local, even if the target itself is local. Additionally, if the unit gets damaged by any means other than ammunition or explosions, such as fall damage and burning, "HitPart" will not fire. Because of this, this event handler is most suitable for when the shooter needs feedback on his shooting, such as target practicing or hitmarker creation.

This EH returns array of sub-arrays [[...],[...], ... [...]]. Each sub-array contains data for the part that was hit as usually multiple parts are hit at the same time (see HitPart_Sample). The structure of each sub-array is listed below.

this addEventHandler ["HitPart", { (_this select 0) params ["_target", "_shooter", "_projectile", "_position", "_velocity", "_selection", "_ammo", "_vector", "_radius", "_surfaceType", "_isDirect", "_instigator"]; }];

  • target: Object - object that got injured/damaged
  • shooter: Object - unit or vehicle that inflicted the damage. If injured by a vehicle collision, 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
  • projectile: Object - object that was fired
  • position: Array format PositionASL - position the bullet impacted
  • velocity: Vector3D - 3D speed at which the bullet impacted
  • selection: Array - array of Strings with named selection of the object that were hit, in the FireGeometry LOD.
  • ammo: Array - ammo info: [hit value, indirect hit value, indirect hit range, explosive damage, ammo class name]; Or, in case of a vehicle collision: [impulse value, 0, 0, 0]; hit and damage values are derived from the projectile's CfgAmmo class, and do not match the actual damage inflicted, which is usually lower due to armor and other factors
  • vector: 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
  • surfaceType: String - surface type struck
  • isDirect: Boolean - true if object was directly hit, false if it was hit by indirect/splash damage
  • Arma 3 logo black.png 2.18 instigator: Object - shot instigator
There is similar event handler that is attached to projectile instead of entity.
This event doesn't fire when miniscule explosive damage is dealt to target entity, but Explosion event will still fire.

IncomingMissile

GAGlobal
Triggered when a unit fires a missile or rocket at the target. For projectiles fired by players this EH only triggers for guided missiles that have locked onto the target.

this addEventHandler ["IncomingMissile", { params ["_target", "_ammo", "_vehicle", "_instigator", "_missile"]; }];

  • target: Object - object the event handler is assigned to
  • ammo: String - ammo type that was fired on the target
  • Arma 3 logo black.png 1.42 vehicle: Object - vehicle that fired the weapon. In case of soldier, unit is returned
  • Arma 3 logo black.png 1.66 instigator: Object - person who pulled the trigger
  • Arma 3 logo black.png 2.10 missile: Object - the incoming missile

Init

GAGlobal
Triggered whenever an entity is created. Cannot be used in scripts, only inside class Eventhandlers in config.

It is recommended to use the PostInit event handler instead of this one when setting entity textures (setObjectTexture, BIS_fnc_initVehicle etc) to avoid networking issues.

e.g:

init = "params ['_entity'];";

params ["_entity"];

  • entity: Object - object the event handler is assigned to

InventoryClosed

GAGlobal
Triggered when the unit closes inventory. Said unit can be non-local when adding the EH, but must be local for the EH to trigger.

this addEventHandler ["InventoryClosed", { params ["_unit", "_container"]; }];

  • unit: Object - object the event handler is assigned to
  • container: Object - connected container or weaponholder

// Delete dropped items when inventory closed player addEventHandler ["InventoryClosed", { params ["_unit", "_container"]; if (_container isKindOf "WeaponHolder") then { deleteVehicle _container; }; }];

InventoryOpened

GAGlobal
Triggered when unit opens inventory. Said unit can be non-local when adding the EH, but must be local for the EH to trigger. End EH main scope with true to override the opening of the inventory in case you wish to handle it yourself:

// Create and open an ammo box when "Inventory" button is pressed player addEventHandler ["InventoryOpened", { player removeAllEventHandlers "InventoryOpened"; _box = "Box_NATO_Ammo_F" createVehicle [0,0,0]; _box setPosASL (player modelToWorldVisualWorld [0,1.5,0.5]); player action ["Gear", _box]; true; // <-- inventory override }];

To return all nearby containers use nearSupplies command.

this addEventHandler ["InventoryOpened", { params ["_unit", "_primaryContainer", "_secondaryContainer"]; }];

  • unit: Object - object the event handler is assigned to
  • primaryContainer: Object - connected container or weaponholder
  • Arma 3 logo black.png 1.66 secondaryContainer: Object - second connected container or weaponholder or objNull

Killed

LALocal
Triggered when the unit is killed.

this addEventHandler ["Killed", { params ["_unit", "_killer", "_instigator", "_useEffects"]; }];

  • unit: Object - the object the event handler is assigned to
  • killer: Object - the object that killed the unit. Contains the unit itself in case of collisions.
  • Arma 3 logo black.png 1.66 instigator: Object - the person who pulled the trigger
  • Arma 3 logo black.png 1.68 useEffects: Boolean - same as useEffects in setDamage alt syntax

LandedStopped

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

this addEventHandler ["LandedStopped", { params ["_plane", "_airportID", "_airportObject"]; }];

LandedTouchDown

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

this addEventHandler ["LandedTouchDown", { params ["_plane", "_airportID", "_airportObject"]; }];

Landing

GAGlobal
Triggered when an AI pilot (or auto-pilot) is preparing for landing. The exact moment of triggering coincides with lowering of the gear ("Gear" EH)

this addEventHandler ["Landing", { params ["_plane", "_airportID", "_isCarrier"]; }];

  • plane: Object - object the event handler is assigned to
  • airportID: Number or Object - ID of the airport or aircraft carrier object
  • isCarrier: Boolean - true if landing on aircraft carrier

LandingCanceled

GAGlobal
Triggered when AI pilot landing is cancelled (for example new order received to land elsewhere). The exact moment of triggering coincides with retracting of the gear ("Gear" EH).
Note: Does not trigger if player switches off auto-pilot. Canceled is spelled with one L

this addEventHandler ["LandingCanceled", { params ["_plane", "_airportID", "_isCarrier"]; }];

  • plane: Object - object the event handler is assigned to
  • airportID: Number or Object - ID of the airport or aircraft carrier object (-1 no airport)
  • isCarrier: Boolean - true if landing on aircraft carrier

LeaningChanged

GAGlobal
Triggered when a soldier leaning factor is changed between -1 (extreme left), 0 (not leaning) and 1 (extreme right)

this addEventHandler ["LeaningChanged", { params ["_unit", "_newLeaning", "_oldLeaning"]; }];

Local

GAGlobal
Triggers when locality of object in MP is changed. The event handler only triggers on the computers that are directly involved in change of locality. So if EH is added to every computer on network, it will only trigger on 2 computers, on the computer that receives ownership of the object (new owner), in which case _this select 1 will be true, and on the computer from which ownership is transferred (old owner), in which case _this select 1 will be false.

this addEventHandler ["Local", { params ["_entity", "_isLocal"]; }];

  • entity: Object - the object that changed locality
  • isLocal: Boolean - if the object is local on given computer

MagazineReloading

LALocal
Triggers when a magazine is removed from a weapon manually or via script. Does NOT trigger on Reloaded event.

this addEventHandler ["MagazineReloading", { params ["_unit", "_weapon", "_muzzle", "_magazine", "_magazineClass", "_ammoCount", "_magazineID", "_magazineCreator"]; }];

  • unit: Object - unit or vehicle to which EH is assigned
  • weapon: String - weapon that got unloaded
  • muzzle: String - weapon's muzzle that got unloaded
  • magazine: Array - magazine info in format [magazineClass, ammoCount, magazineID, magazineCreator], where:
    • magazineClass: String - class name of the magazine
    • ammoCount: Number - amount of ammo in magazine
    • magazineID: Number - global magazine id
    • magazineCreator: Number - owner of the magazine creator

MagazineUnloaded

LALocal
Triggers when a magazine is removed from a weapon manually or via script. Does NOT trigger on Reloaded event.

this addEventHandler ["MagazineUnloaded", { params ["_unit", "_weapon", "_muzzle", "_magazine", "_magazineClass", "_ammoCount", "_magazineID", "_magazineCreator"]; }];

  • unit: Object - unit or vehicle to which EH is assigned
  • weapon: String - weapon that got unloaded
  • muzzle: String - weapon's muzzle that got unloaded
  • magazine: Array - magazine info in format [magazineClass, ammoCount, magazineID, magazineCreator], where:
    • magazineClass: String - class name of the magazine
    • ammoCount: Number - amount of ammo in magazine
    • magazineID: Number - global magazine id
    • magazineCreator: Number - owner of the magazine creator

OpticsModeChanged

LALocal
Triggers everytime a local unit changes optic mode. This could be either through the setOpticsMode command or by the player switching to the next optic mode using e.g NUM / or Ctrl + Right Mouse Button.

this addEventHandler ["OpticsModeChanged", { params ["_unit", "_opticsClass", "_newMode", "_oldMode", "_isADS"]; }];

OpticsSwitch

LALocal
Triggers at the start of the camera transition from GUNNER to INTERNAL/EXTERNAL and vice-versa. So anytime the right mouse button is pressed and there is a GUNNER view available or are currently in it, this triggers. Works in vehicles and FFV as well. See also cameraView.

this addEventHandler ["OpticsSwitch", { params ["_unit", "_isADS"]; }];

  • unit: Object - the unit
  • isADS: Boolean - if the new view is GUNNER

PathCalculated

LALocal
Triggers when a path has been calculated for the unit. Works for both agents and normal AI units.
Note that paths to far destinations are typically calculated in segments. When the unit completes a segment, a new path is calculated and this is continued until the unit reaches its destination.

this addEventHandler ["PathCalculated", { params ["_unit", "_path"]; }];

  • unit: Object - the unit/agent for which the path was calculated
  • path: Array - the array of positions representing the path (PositionASL)

PeriscopeElevationChanged

Fires every frame during periscope elevation animation.

this addEventHandler ["PeriscopeElevationChanged", { params ["_vehicle", "_turret", "_elevation", "_direction", "_userIsBlocked"]; }];

  • vehicle: Object - the vehicle this EH is assigned to
  • turret: Array - the turret which periscope is changing elevation
  • elevation: Number - current periscope elevation (changes with each simulation). See also periscopeElevation, elevatePeriscope
  • direction: Number - 1: moves up, 0: stopped, -1: moves down; when direction returns 0, this also means the event handler fired for the last time for this elevation.
  • userIsBlocked: Boolean - whether or not the user ability to override is blocked. See also periscopeElevation, elevatePeriscope

PostInit

GAGlobal
Triggered whenever an entity is created and initialized. Cannot be used in scripts, only inside class Eventhandlers in config.

It is recommended to use this event handler instead of the Init one when setting entity textures (setObjectTexture, BIS_fnc_initVehicle etc) to avoid networking issues.

e.g:

postInit = "params ['_entity'];";
postinit = "params ['_entity']; if (local _entity) then { [_entity, '', [], false] call BIS_fnc_initVehicle };";

params ["_entity"];

  • entity: Object - object the event handler is assigned to

PostReset

Obsolete - triggers after PP effects have been reset by the engine.

Put

GAGlobal
Triggers when a unit puts an item in a container.

Arma 3 logo black.png 2.14 This event handler can be added to a container.

this addEventHandler ["Put", { params ["_unit", "_container", "_item"]; }];

  • unit: Object - unit who put the item in the container
  • container: Object - the container into which the item was placed (vehicle, box, etc.)
  • item: String - the class name of the moved item
This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.

PylonChanged

LALocal
Triggers when an aircraft's pylon changes magazine type:

vehicle player addEventHandler ["PylonChanged", { params ["_vehicle", "_pylonIndex", "_oldMagazine", "_newMagazine"]; }];

This event generally triggers twice for a swap, first unload then load, e.g:
// [myVehicle, 1, "oldMagClass", ""] // [myVehicle, 1, "", "newMagClass"]

Reloaded

LALocal
Triggers when a weapon is reloaded with a new magazine. For more information see: Reloaded

this addEventHandler ["Reloaded", { params ["_unit", "_weapon", "_muzzle", "_newMagazine", "_oldMagazine"]; }];

  • unit: Object - unit or vehicle to which EH is assigned
  • weapon: String - weapon that got reloaded
  • muzzle: String - weapon's muzzle that got reloaded
  • newMagazine: Array - new magazine info
  • oldMagazine: Array or Nothing - old magazine info

Respawn

LALocal
Triggered when a unit respawns.

this addEventHandler ["Respawn", { params ["_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

RopeAttach

Triggered when a rope is attached to an object.
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each attached rope.

this addEventHandler ["RopeAttach", { params ["_object1", "_rope", "_object2"]; }];

  • object1: Object - object to which the event handler is assigned.
  • rope: Object - the rope being attached between object 1 and object 2.
  • object2: Object - the object that is being attached to object 1 via rope.

RopeBreak

Triggered when a rope is detached from an object.
In the case of sling loading, this event handler must be assigned to the helicopter and will trigger for each detached rope.

this addEventHandler ["RopeBreak", { params ["_rope", "_object1", "_object2"]; }];

  • rope: Object - the rope that connected object 1 and object 2.
  • object1: Object - object to which the event handler is assigned.
  • object2: Object - the object that was connected to object 1 with a rope.

SeatSwitched

GAGlobal
Triggered when unit changes seat within vehicle. EH returns both units switching seats. If switching seats with an empty seat, one of the returned units will be objNull. The new position can be obtained with assignedVehicleRole. This EH must be assigned to a vehicle.

this addEventHandler ["SeatSwitched", { params ["_vehicle", "_unit1", "_unit2"]; }];

  • vehicle: Object - vehicle to which the event handler is assigned.
  • unit1: Object - unit switching seat.
  • unit2: Object - unit switching seat.

SeatSwitchedMan

GAGlobal
Triggered when unit changes seat within vehicle. EH returns both units switching seats. If switching seats with an empty seat, one of the returned units will be objNull. The new position can be obtained with assignedVehicleRole <unit>. This EH must be assigned to a unit and not a vehicle. This EH is persistent and will be transferred to the new unit after respawn, but only if it was assigned where unit was local.

this addEventHandler ["SeatSwitchedMan", { params ["_unit1", "_unit2", "_vehicle"]; }];

  • unit1: Object - unit switching seat.
  • unit2: Object - unit with which unit1 is switching seat.
  • vehicle: Object - vehicle where switching seats is taking place.

SelectedActionChanged

RTM helicopter user action event

this addEventHandler ["SelectedActionChanged", { params ["_caller", "_target", "_enumNumber", "_actionId"]; }];

Limited or non-existent functionality.

SelectedActionPerformed

RTM helicopter user action event

this addEventHandler ["SelectedActionPerformed", { params ["_caller", "_target", "_enumNumber", "_actionId"]; }];

Limited or non-existent functionality.

SelectedRotorLibActionChanged

RTM helicopter user action event

this addEventHandler ["SelectedRotorLibActionChanged", { params ["_caller", "_target", "_enumNumber", "_actionId"]; }];

Limited or non-existent functionality.

SelectedRotorLibActionPerformed

RTM helicopter user action event

this addEventHandler ["SelectedRotorLibActionPerformed", { params ["_caller", "_target", "_enumNumber", "_actionId"]; }];

Works only for key press combination RCtrl + W, which is the binding for helicopter wheels brakes.

It fires with or without Advanced Flight Model enabled. The enum number returned is 4 and 5, probably because the enum is structured like this:

  • 0: HelicopterAutoTrimOn
  • 1: HelicopterAutoTrimOff
  • 2: HelicopterTrimOn
  • 3: HelicopterTrimOff
  • 4: WheelsBrakeOn
  • 5: WheelsBrakeOff

SlotItemChanged

GAGlobal
Triggered when any of the following slots get assigned or unassigned: Items - Map, GPS, Radio, Watch, Compass, Helmet, Goggles, NVG; Weapon - Binoculars; Containers - Uniform, Vest, Backpack.

this addEventHandler ["SlotItemChanged", { params ["_unit", "_name", "_slot", "_assigned", "_weapon"]; }];

SoundPlayed

LALocal
Triggered when player is making noises when injured or fatigued for example. The number param passed to the EH code points to the sound origin:

  1. Breath
  2. Breath Injured
  3. Breath Scuba
  4. Injured
  5. Pulsation
  6. Hit Scream
  7. Burning
  8. Drowning
  9. Drown
  10. Gasping
  11. Stabilizing
  12. Healing
  13. Healing With Medikit
  14. Recovered
  15. Breath Held

this addEventHandler ["SoundPlayed", { params ["_unit", "_soundID"]; }];

  • unit: Object - unit to which the event handler is assigned
  • soundID: Number - sound origin
Since Arma 3 logo black.png 2.12 returning a Number from last added EH in range from 0 to 5 will alter the volume of played sound from mute to max volume.

Suppressed

LALocal
Triggers when enemy projectile is passing by closer than defined suppression radius ammo value in config. Can be made to trigger for the same side if the side is set as enemy to itself (with setFriend).

this addEventHandler ["Suppressed", { params ["_unit", "_distance", "_shooter", "_instigator", "_ammoObject", "_ammoClassName", "_ammoConfig"]; }];

  • unit: Object - unit to which the event is assigned
  • distance: Number - distance of the projectile pass-by
  • shooter: Object - who (or what) fired - vehicle or drone
  • instigator: Object - who pressed the trigger. Instigator is different from the shooter when player is operator of UAV for example
  • ammoObject: Object - the ammunition itself
  • ammoClassName: String - the ammunition's classname
  • ammoConfig: Config - the ammunition's CfgAmmo config path

Take

GAGlobal
Triggers when a unit takes an item from a container.

Arma 3 logo black.png 2.14 This event handler can be added to a container.

this addEventHandler ["Take", { params ["_unit", "_container", "_item"]; }];

  • unit: Object - unit who took the item from the container
  • container: Object - the container from which the item was taken (vehicle, box, etc.)
  • item: String - the class name of the taken item
This EH could also trigger when unit replaces magazine in weapon with another magazine from unit containers (uniform, vest, backpack) during reload.

TaskSetAsCurrent

Triggers when player's current task changes

this addEventHandler ["TaskSetAsCurrent", { params ["_unit", "_task"]; }];

  • unit: Object - the player to whom the event handler is assigned
  • task: Task - the new current task

TurnIn

Triggers when member of crew in a vehicle uses Turn In action

this addEventHandler ["TurnIn", { params ["_vehicle", "_unit", "_turret"]; }];

  • vehicle: Object - the vehicle the event handler is assigned to
  • unit: Object - the unit performing the Turn In action
  • turret: Array - turret path

TurnOut

Triggers when member of crew in a vehicle uses Turn Out action

this addEventHandler ["TurnOut", { params ["_vehicle", "_unit", "_turret"]; }];

  • vehicle: Object - the vehicle the event handler is assigned to
  • unit: Object - the unit performing the Turn Out action
  • turret: Array - turret path

VisionModeChanged

Triggers when the assigned vehicle/unit's vision mode has changed.

player addEventHandler ["VisionModeChanged", { params ["_person", "_visionMode", "_TIindex", "_visionModePrev", "_TIindexPrev", "_vehicle", "_turret"]; }];

  • person: Object - unit for whom the vision mode changes
  • visionMode: Number - vision mode index
  • TIindex: Number - thermal vision mode index; will return -1 when visionMode is not 2
  • visionModePrev: Number - last vision mode
  • TIindexPrev: Number - last TI mode; will return -1 when visionModePrev is not 2
  • vehicle: Object - if unit is in a vehicle or controlling a UAV, this will be the vehicle
  • turret: Array - turret path to the turret occupied by the unit, or [] if not on turret

WeaponAssembled

GAGlobal
Triggers when a weapon gets assembled. EH must be attached to the unit and not the weapon.

this addEventHandler ["WeaponAssembled", { params ["_unit", "_weapon", "_primaryBag", "_secondaryBag"]; }];

  • unit: Object - object the event handler is assigned to
  • weapon: Object - object of the assembled weapon
  • Arma 3 logo black.png 2.18 primaryBag: Object - primary bag (just before it is deleted)
  • Arma 3 logo black.png 2.18 secondaryBag: Object - secondary bag (just before it is deleted)

WeaponChanged

Fires on weapon switch and firemode switch. Does not fire for player units inside vehicles (but does fire for vehicles with players in them).
The locality is unknown, but it is known that this EH behaves like currentWeapon, currentWeaponMode and currentMuzzle in terms of locality.

this addEventHandler ["WeaponChanged", { params ["_object", "_oldWeapon", "_newWeapon", "_oldMode", "_newMode", "_oldMuzzle", "_newMuzzle", "_turretIndex"]; }];

  • object: Object - the unit or vehicle the event handler is assigned to
  • oldWeapon: String - the class name of the previous weapon
  • newWeapon: String - the class name of the new weapon (same as currentWeapon)
  • oldMode: String - the previous weapon mode
  • newMode: String - the new weapon mode (same as currentWeaponMode)
  • oldMuzzle: String - the previous weapon muzzle
  • newMuzzle: String - the new weapon muzzle (same as currentMuzzle)
  • turretIndex: Array format Turret Path - the turret path, or nil if object is not a transport vehicle

WeaponDeployed

GAGlobal
Triggers when the deployed state of a weapon or bipod changes.
Note: A weapon cannot be rested and deployed at the same time.

this addEventHandler ["WeaponDeployed", { params ["_unit", "_isDeployed"]; }];

  • unit: Object - object the event handler is assigned to
  • isDeployed: Boolean - true if deployed

WeaponDisassembled

GAGlobal
Triggers when a weapon gets disassembled. EH must be attached to the unit and not the weapon.
Note: As of Arma 3 v1.32, this event does not fire if the weapon is not local.

this addEventHandler ["WeaponDisassembled", { params ["_unit", "_primaryBag", "_secondaryBag", "_weapon"]; }];

  • 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
  • Arma 3 logo black.png 2.18 weapon: Object - disassembled weapon (just before it is moved out of the world)

WeaponRested

LALocal
Triggers when weapon rested state changes (weapon near a surface that can provide weapon support).
Note: A weapon cannot be rested and deployed at the same time.

this addEventHandler ["WeaponRested", { params ["_unit", "_isRested"]; }];

  • unit: Object - object the event handler is assigned to
  • isRested: Boolean - true if rested


Multiplayer Event Handlers

Global object event handler, executed on every connected machine.

Commands:

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

MPHit

GAGlobalGEGlobal
Triggered when the unit is hit/damaged. EH can be added on any machine and EH code will trigger globally on every connected client and server. This EH is clever enough to be triggered globally only once even if added on all clients or a single client that is then disconnected, EH will still trigger globally only once.

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. Can also trigger several times for an explosion (direct and indirect damage). Does not fire when a unit is set to allowDamage false. However it will fire with "HandleDamage" EH added alongside stopping unit from taking damage (unit addEventHandler ["HandleDamage", { 0 }];. Will not trigger once the unit is dead.

Note: call a function from the MPHit EH code space rather than defining 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!

this addMPEventHandler ["MPHit", { params ["_unit", "_causedBy", "_damage", "_instigator"]; }];

  • 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
  • Arma 3 logo black.png 1.66 instigator: Object - person who pulled the trigger

MPKilled

GAGlobalGEGlobal
Triggered when the unit is killed. EH can be added on any machine and EH code will trigger globally on every connected client and server. This EH has a safeguard measure so that even if it's added on all clients or a single client that is then disconnected, EH will still trigger globally only once per client.

this addMPEventHandler ["MPKilled", { params ["_unit", "_killer", "_instigator", "_useEffects"]; }];

  • unit: Object - object the event handler is assigned to
  • killer: Object - object that killed the unit. Contains the unit itself in case of collisions
  • Arma 3 logo black.png 1.66 instigator: Object - person who pulled the trigger
  • Arma 3 logo black.png 1.68 useEffects: Boolean - same as useEffects in setDamage alt syntax

MPRespawn

GAGlobalLELocal
Triggered when a unit, it is assigned to, respawns. This EH does not work as one would expect MP EH should work like. It is only triggered on one 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.

MPRespawn EH expects the EH code to return an array in Position format which will be used to place the respawned unit at the desired coordinates.
For example: player addMPEventHandler ["MPRespawn", { [1234, 1234, 0] }]; will place player at [1234,1234,0] immediately on respawn.

this addMPEventHandler ["MPRespawn", { params ["_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.


Mission Event Handlers

Mission Event Handlers are specific EHs that are anchored to the running mission and automatically removed when mission is over.

Commands:

Curator Event Handlers

LALocalLELocal
Arma 3: Curator Event Handlers are also added with the addEventHandler command. They are executed only where the curator is local - on the machine that is in control of it.

These Event Handlers must be added to the curator object/module, not the player!

Commands:

CuratorFeedbackMessage

LALocal
Triggered when curator attempts invalid action in curator interface.

Each error has its own unique ID, recognized values are:

  • 003 - when trying to teleport camera outside of curatorCameraArea
  • 101 - trying to place an object when placing is disabled using setCuratorCoef "place"
  • 102 - trying to place an object which is too expensive (cost set in curatorObjectRegistered multiplied by setCuratorCoef "place" is larger than curatorPoints)
  • 103 - trying to place an object outside of curatorEditingArea
  • 104 - items of a placed composition were skipped / could not be placed (since Arma 3 v2.06)
  • 201 - trying to place a waypoint when waypoint placing is disabled
  • 202 - trying to place a waypoint which is too expensive (cost set by setCuratorWaypointCost multiplied by setCuratorCoef "place" is larger than curatorPoints)
  • 206 - trying to place a waypoint when no AI unit is selected
  • 301 - trying to move or rotate an entity when editing is disabled using setCuratorCoef "edit"
  • 302 - trying to move or rotate an entity when it is too expensive (entity cost multiplied by setCuratorCoef "edit" is larger than curatorPoints)
  • 303 - trying to move an entity outside of curatorEditingArea
  • 304 - trying to move or rotate an entity which is outside of curatorEditingArea
  • 307 - trying to move or rotate a player (players cannot be manipulated with)
  • 401 - trying to delete an entity when deleting is disabled using setCuratorCoef "delete"
  • 402 - trying to delete an entity which is too expensive (cost multiplied by setCuratorCoef "delete" is larger than curatorPoints)
  • 404 - trying to delete an entity which is outside of curatorEditingArea
  • 405 - trying to delete an entity which has non-editable crew in it
  • 407 - trying to delete a player (players cannot be manipulated with)
  • 501 - trying to destroy an object when destroying is disabled using setCuratorCoef "destroy"
  • 502 - trying to destroy an object which is too expensive (cost multiplied by setCuratorCoef "destroy" is larger than curatorPoints)
  • 504 - trying to destroy an object which is outside of curatorEditingArea
  • 505 - trying to destroy an object which has non-editable crew in it
  • 506 - trying to destroy an object when no object is selected
  • 507 - trying to destroy a player (players cannot be manipulated with)

this addEventHandler ["CuratorFeedbackMessage", { params ["_curator", "_errorID"]; }];

CuratorGroupDoubleClicked

LALocal
Triggered when a group is double-clicked on in curator interface.

this addEventHandler ["CuratorGroupDoubleClicked", { params ["_curator", "_group"]; }];

CuratorGroupPlaced

LALocal
Triggered when new group is placed in curator interface.

this addEventHandler ["CuratorGroupPlaced", { params ["_curator", "_group"]; }];

CuratorGroupSelectionChanged

LALocal
Triggered when a group is selected in curator interface.

this addEventHandler ["CuratorGroupSelectionChanged", { params ["_curator", "_group"]; }];

CuratorMarkerDeleted

LALocal
Triggered when a marker is deleted in curator interface.

this addEventHandler ["CuratorMarkerDeleted", { params ["_curator", "_marker"]; }];

CuratorMarkerDoubleClicked

LALocal
Triggered when a marker is double-clicked on in curator interface.

this addEventHandler ["CuratorMarkerDoubleClicked", { params ["_curator", "_marker"]; }];

CuratorMarkerEdited

LALocal
Triggered when a marker is moved in curator interface.

this addEventHandler ["CuratorMarkerEdited", { params ["_curator", "_marker"]; }];

CuratorMarkerPlaced

LALocal
Triggered when new marker is placed in curator interface.

this addEventHandler ["CuratorMarkerPlaced", { params ["_curator", "_marker"]; }];

CuratorMarkerSelectionChanged

LALocal
Triggered when a marker is selected in curator interface.

this addEventHandler ["CuratorMarkerSelectionChanged", { params ["_curator", "_marker"]; }];

CuratorObjectDeleted

LALocal
Triggered when an object is deleted in curator interface.

this addEventHandler ["CuratorObjectDeleted", { params ["_curator", "_entity"]; }];

CuratorObjectDoubleClicked

LALocal
Triggered when an object is double-clicked on in curator interface.

this addEventHandler ["CuratorObjectDoubleClicked", { params ["_curator", "_entity"]; }];

CuratorObjectEdited

LALocal
Triggered when an object is moved or rotated in curator interface.

this addEventHandler ["CuratorObjectEdited", { params ["_curator", "_entity"]; }];

CuratorObjectPlaced

LALocal
Triggered when new object is placed in curator interface. This event handler will trigger individually for each unit in a placed group - excluding the crew in vehicles.

this addEventHandler ["CuratorObjectPlaced", { params ["_curator", "_entity"]; }];

CuratorObjectRegistered

LALocal
Triggered when player enters curator interface. Assign curator cost to every object in the game. This is the primary method that a mission designer can use to limit the objects a curator can place.

this addEventHandler ["CuratorObjectRegistered", { params ["_curator", "_input"]; }];

CuratorObjectSelectionChanged

LALocal
Triggered when an object is selected in curator interface.

this addEventHandler ["CuratorObjectSelectionChanged", { params ["_curator", "_entity"]; }];

CuratorPinged

LALocal
Triggered when a player pings his curator(s) by pressing the Zeus key.

this addEventHandler ["CuratorPinged", { params ["_curator", "_player"]; }];

CuratorSelectionPresetLoaded

LALocal
Triggered when a selection preset is loaded using the respective number key or through script.

this addEventHandler ["CuratorSelectionPresetLoaded", { params ["_curator", "_numkey"]; }];

CuratorSelectionPresetSaved

LALocal
Triggered when a selection preset is saved using the respective CTRL + number key or set through script.

this addEventHandler ["CuratorSelectionPresetSaved", { params ["_curator", "_numkey"]; }];

CuratorWaypointDeleted

LALocal
Triggered when a waypoint is deleted in curator interface.

this addEventHandler ["CuratorWaypointDeleted", { params ["_curator", "_waypoint"]; }];

CuratorWaypointDoubleClicked

LALocal
Triggered when a waypoint is double-clicked on in curator interface.

this addEventHandler ["CuratorWaypointDoubleClicked", { params ["_curator", "_waypoint"]; }];

CuratorWaypointEdited

LALocal
Triggered when a waypoint is moved in curator interface.

this addEventHandler ["CuratorWaypointEdited", { params ["_curator", "_waypoint"]; }];

CuratorWaypointPlaced

LALocal
Triggered when new waypoint is placed in curator interface.

this addEventHandler ["CuratorWaypointPlaced", { params ["_curator", "_group", "_waypointID"]; }];

CuratorWaypointSelectionChanged

LALocal
Triggered when a waypoint is selected in curator interface.

this addEventHandler ["CuratorWaypointSelectionChanged", { params ["_curator", "_waypoint"]; }];

UserAction Event Handlers

UserAction Event Handlers are events that trigger on user action.

Commands:

Activate

addUserActionEventHandler ["KeyName", "Activate", { params ["_activated"]; }];

Deactivate

addUserActionEventHandler ["KeyName", "Deactivate", { params ["_activated"]; }];

Analog

addUserActionEventHandler ["KeyName", "Analog", { params ["_value"]; }];

  • value: Number - input device's analog value

Projectile Event Handlers

Commands:

Deleted

_projectile addEventHandler ["Deleted", { params ["_projectile"]; }];

Deflected

_projectile addEventHandler ["Deflected", { params ["_projectile", "_position", "_velocity", "_hitObject"]; }];

Explode

LALocal

_projectile addEventHandler ["Explode", { params ["_projectile", "_position", "_velocity"]; }];

HitExplosion

_projectile addEventHandler ["HitExplosion", { params ["_projectile", "_hitEntity", "_projectileOwner", "_hitSelections", "_instigator"]; }];

  • projectile: Object
  • hitEntity: Object
  • projectileOwner: Object
  • hitSelections: Array of Arrays - same list of FireGeometry components that entity HitPart gets but only contains:
    • position: Array format PositionASL - position of impact
    • vector: Array format 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
    • selection: String - named selection of the object that was hit, in the FireGeometry LOD.
    • radius: Number - radius (size) of component hit
    • surface: String - surface type struck
  • Arma 3 logo black.png 2.18 instigator: Object - shot instigator

HitPart

Triggered when the projectile hits any surface.

_projectile addEventHandler ["HitPart", { params ["_projectile", "_hitEntity", "_projectileOwner", "_pos", "_velocity", "_normal", "_components", "_radius" ,"_surfaceType", "_instigator"]; }];

Only triggers for direct hits and not splash damage, unlike entity HitPart. For splash damage, use HitExplosion.

Init

Triggered whenever a projectile is created. Cannot be used in scripts, only inside class Eventhandlers in config.

init = "params ['_projectile'];";

params ["_projectile"];

  • projectile: Object - object the event handler is assigned to

MineActivated

LALocal LELocal

_projectile addEventHandler ["MineActivated", { params ["_projectile", "_isActive"]; }];

  • projectile: Object
  • isActive: Boolean - new active state of the mine

Penetrated

This event fires as many times as the projectile penetrates a surface.

_projectile addEventHandler ["Penetrated", { params ["_projectile", "_hitObject", "_surfaceType", "_entryPoint", "_exitPoint", "_exitVector"]; }];

SubmunitionCreated

This event fires as many times as submunitions are created.

_projectile addEventHandler ["SubmunitionCreated", { params ["_projectile", "_submunitionProjectile", "_position", "_velocity"]; }];

Group Event Handlers

Commands:

CombatModeChanged

Triggers when the group's behaviour changes (see behaviour, setBehaviour)

_group addEventHandler ["CombatModeChanged", { params ["_group", "_newMode"]; }];

CommandChanged

_group addEventHandler ["CommandChanged", { params ["_group", "_newCommand"]; }];

  • group: Group
  • newCommand: String, can be one of:
    "NO CMD" NoCommand
    "WAIT" Wait
    "ATTACK" Attack
    "Suppress" Suppress
    "HIDE" Hide
    "MOVE" Move
    "HOOK CARGO" HookCargo
    "UNHOOK CARGO" UnhookCargo
    "VIV GETIN" ViVGetIn
    "VIV GETOUT" ViVGetOut
    "VIV UNLOAD" ViVUnload
    "HEAL" Heal
    "REPAIR" Repair
    "REFUEL" Refuel
    "REARM" Rearm
    "SUPPORT" Support
    "JOIN" Join
    "GET IN" GetIn
    "FIRE" Fire
    "GET OUT" GetOut
    "STOP" Stop
    "EXPECT" Expect
    "ACTION" Action
    "SCRIPTED" Scripted
    "DISMISS" Dismiss
    "HEAL SOLDIER" HealSoldier
    "PATCH SOLDIER" PatchSoldier
    "FIRST AID" FirstAid
    "HEAL SELF" HealSoldierSelf
    "ATTACK AND FIRE" AttackAndFire
    "CARRY SOLDIER" CarrySoldier
    "DROP CARRIED" DropCarried
    "TAKE BAG" TakeBag
    "ASSEMBLE" Assemble
    "DISASSEMBLE" DisAssemble
    "DROP BAG" DropBag
    "OPEN BAG" OpenBag
    "IRLASER ON" IRLaserOn
    "IRLASER OFF" IRLaserOff
    "GUN LIGHT ON" GunLightOn
    "GUN LIGHT OFF" GunLightOff
    "FIRE AT POSITION" FireAtPosition
    "REPAIR VEHICLE" RepairVehicle
    "OPEN PARA" OpenParachute
    "KEEP DEPTH LEADER" KeepDepthLeader
    "KEEP DEPTH UND SURF" KeepDepthUnderSurface
    "KEEP DEPTH ABV SURF" KeepDepthAboveSurface
    "KEEP DEPTH BOTTOM" KeepDepthBottom
    "PUT IN" PutIn
    "UNLOAD FROM" UnloadFrom
    "USE CONTAINER MAGAZINE" UseContainerMagazine
    "ACTIVATE MINE" ActivateMine
    "DISABLE MINE" DisableMine
    ↑ Back to spoiler's top

Deleted

_group addEventHandler ["Deleted", { params ["_group"]; }];

Empty

_group addEventHandler ["Empty", { params ["_group"]; }];

EnableAttackChanged

_group addEventHandler ["EnableAttackChanged", { params ["_group", "_attackEnabled"]; }];

EnemyDetected

_group addEventHandler ["EnemyDetected", { params ["_group", "_newTarget"]; }];

Fleeing

_group addEventHandler ["Fleeing", { params ["_group", "_fleeingNow"]; }];

FormationChanged

_group addEventHandler ["FormationChanged", { params ["_group", "_newFormation"]; }];

GroupIdChanged

_group addEventHandler ["GroupIdChanged", { params ["_group", "_newGroupId"]; }];

KnowsAboutChanged

_group addEventHandler ["KnowsAboutChanged", { params ["_group", "_targetUnit", "_newKnowsAbout", "_oldKnowsAbout"]; }];

LeaderChanged

_group addEventHandler ["LeaderChanged", { params ["_group", "_newLeader"]; }];

Local

_group addEventHandler ["Local", { params ["_group", "_isLocal"]; }];

SpeedModeChanged

_group addEventHandler ["SpeedModeChanged", { params ["_group", "_newSpeedMode"]; }];

UnitJoined

_group addEventHandler ["UnitJoined", { params ["_group", "_newUnit"]; }];

UnitKilled

LALocal
Triggered when a unit in the group is killed.

_group addEventHandler ["UnitKilled", { params ["_group", "_unit", "_killer", "_instigator", "_useEffects"]; }];

  • group: Group - the group the event handler is assigned to
  • unit: Object - the unit that was killed
  • killer: Object - the object that killed the unit. Contains the unit itself in case of collisions.
  • instigator: Object - the person who pulled the trigger
  • useEffects: Boolean - same as useEffects in setDamage alt syntax

UnitLeft

_group addEventHandler ["UnitLeft", { params ["_group", "_oldUnit"]; }];

VehicleAdded

_group addEventHandler ["VehicleAdded", { params ["_group", "_newVehicle"]; }];

VehicleRemoved

_group addEventHandler ["VehicleRemoved", { params ["_group", "_oldVehicle"]; }];

WaypointComplete

_group addEventHandler ["WaypointComplete", { params ["_group", "_waypointIndex"]; }];


Game UI Event Handlers

In Game UI Event Handlers trigger when user scrolls or activates in game action menu.
The following mission EHs are available in Arma 3:

Only one event of each kind can exist, adding another will overwrite the existing one.

Commands:


Control/Display UI Event Handlers

Commands:


Music Event Handlers

Music event handler, always executed on the computer where it was added.

Does not apply to interface-less machines (dedicated server, headless client).

Commands:

MusicStart

Triggers when CfgMusic sound starts playing, after being executed with playMusic command.

addMusicEventHandler ["MusicStart", { params ["_musicClassname", "_eventHandlerID", "_currentPosition", "_totalLength"]; }];

MusicStop

Triggers when CfgMusic sound finished playing, after being executed with playMusic command.
Arma 3 logo black.png 2.14 playMusic "" triggers this event if a music is currently playing.

addMusicEventHandler ["MusicStop", { params ["_musicClassname", "_eventHandlerID", "_currentPosition", "_totalLength"]; }];


Eden Editor

Commands:


Public Variable Broadcast Event

Commands:

Triggers when missionNamespace variable EH is associated with is sent over network via publicVariable, publicVariableServer or publicVariableClient commands.

Unlike with other types of EHs, there is no way of removing added public variable event handler


Weapon Muzzle Config Events

There are three event handlers that can be set on weapon in config:

  • "Fired" - when muzzle fired
  • "Reload" - before muzzle is reloaded
  • "Reloaded" - after muzzle is reloaded
class CfgWeapons
{
	class RifleCore;
	class TAG_Rifle : RifleCore
	{
		class EventHandlers
		{
			fired		= "systemChat format ['fired weapon EH output: %1 [time: %2]', _this, time]";
			reload		= "systemChat format ['reload weapon EH output: %1 [time: %2]', _this, time]";
			reloaded	= "systemChat format ['reloaded weapon EH output: %1 [time: %2]', _this, time]";
		};
	};
};


Ammo Config Events

There are three event handlers that can be set on ammo in config:

  • "init" - when the ammo is created, by any mean (fired, created, etc). Params: [shot]
  • "fired" - when the ammo is fired (legacy). Params: same as in entity EH "Fired".
  • "ammoHit" - when the ammo hits anything (can trigger multiple times). Params: [shot, shooter, hitobj, pos, velocity, hitComponents, [hit, indirecthit, indirecthitrange, explosive, name], normal, explode, instigator (since Arma 3 v2.18)]
class CfgAmmo
{
	class BulletCore;
	class TAG_Bullet : BulletCore
	{
		class EventHandlers
		{
			init	= "systemChat format ['init ammo EH output: %1 [time: %2]', _this, time]";
			fired	= "systemChat format ['fired ammo EH output: %1 [time: %2]', _this, time]";
			ammoHit	= "systemChat format ['ammoHit EH output: %1 [time: %2]', _this, time]";
		};
	};
};


BI Scripted Events

Commands:


Jump to the top of the page