Event Handlers – Arma 3

From Bohemia Interactive Community
Jump to navigation Jump to search
(→‎HandleDamage: cleanup, locality)
Line 482: Line 482:


== PostReset ==
== PostReset ==
From .\functions_f\Feedback\fn_feedbackInit.sqf
//checks whether PPs were reseted by engine
BIS_EnginePPReset = false;
if (isNil {player getVariable "BIS_fnc_feedback_postResetHandler"}) then {
player setVariable ["BIS_fnc_feedback_postResetHandler", true];
player addeventhandler ["PostReset",{BIS_EnginePPReset = true;} ];
};


== SoundPlayed ==
== SoundPlayed ==

Revision as of 06:06, 20 September 2013

Introduction

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

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

General MP Note

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

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

Event Scripts

See also: Event Scripts for special event triggered scripts.

Event Handler List

AnimChanged

Triggered everytime a new animation is started.

Global. Global effect EventHandler

Passed array: [unit, anim]

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

AnimDone

Trigerred everytime an animation is finished.

Unknown MP behaviour. Probably local.

Passed array: [unit, anim]

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

AnimStateChanged

Trigerred everytime an animation state changes. Unlike AnimChanged and AnimDone, it is triggered for all animation states in a sequence.

arma2 1.00.gif

Unknown MP behaviour. Probably local.

Passed array: [unit, anim]

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

Dammaged

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

Global. Global effect EventHandler

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

Passed array: [unit, selectionName, damage]

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

Engine

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

Global. Global effect EventHandler

Passed array: [vehicle, engineState]

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

Explosion

Triggered when a vehicle or unit is damaged by a nearby explosion.

arma3 0.76.gif

Passed array: [vehicle, damage]

  • vehicle: Object - Object the event handler is assigned to
  • damage: Number - Damage inflicted to the object

Fired

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

Global. Global effect EventHandler

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

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

FiredNear

Triggered when a weapon is fired somewhere near the unit or vehicle.
It is also triggered if the unit itself is firing.

arma2 1.00.gif Global. Global effect EventHandler

(Exception(s): the Throw weapon wont broadcast the FiredNear event)

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

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

Fuel

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

Global. Global effect EventHandler

Passed array: [vehicle, fuelState]

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

Gear

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

Global. Global effect EventHandler Passed array: [vehicle, gearState]

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

GetIn

arguments global.gif effects local.gif

Triggers when a unit enters a vehicle. It can be assigned to a remote vehicle but will only fire on the PC where the actual addEventHandler command was executed. This EH is neither triggered upon a change of positions within the same vehicle nor by the moveInXXXX commands. However it is triggered by a "GetInXXXX" action.

Passed array: [vehicle, position, unit]

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

In vehicles with multi-turret setup, entering any turret will show "gunner" for position. You can get the actual turret information from the unit itself: _heli addEventHandler ["GetIn", { hint str assignedVehicleRole (_this select 2); }];

GetOut

arguments global.gif effects local.gif

Triggers when a unit gets out from a vehicle. It can be assigned to a remote vehicle but will only fire on the PC where the actual addEventHandler command was executed. This EH is triggered by both the moveOut command and by "GetOut" action.

Passed array: [vehicle, position, unit]

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

In vehicles with multi-turret setup, exiting any turret will show "gunner" for position. You can get the actual turret information from the unit itself: _heli addEventHandler ["GetOut", { hint str assignedVehicleRole (_this select 2); }];

HandleDamage

arma2 1.00.gif arguments local.gif effects local.gif

Triggers when the unit is damaged and fires for each damaged selection separately. Works with all vehicles. This EH must be added where unit is local and will only fire on the PC it was added.

Code provided must return a value what should be the damage of given selection after processing. No return value or return value 0 will make the unit invulnerable if damage is not scripted in other ways. If you want default processing to be done, be sure to return _this select 2. You can also use setDamage and setHit in combination for additional damage handling.

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

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

Example:

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

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

"T=11692.9 : [B Alpha 2-2:1,"head",0.0179969,<NULL-object>,"B_65x39_Caseless"]"
"T=11692.9 : [B Alpha 2-2:1,"",0.850484,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11692.9 : [B Alpha 2-2:1,"",0.850484,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11692.9 : [B Alpha 2-2:1,"head",0.0179969,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11692.9 : [B Alpha 2-2:1,"body",0.0939217,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11692.9 : [B Alpha 2-2:1,"hands",0.109993,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"

"T=11694.8 : [B Alpha 2-2:1,"head",0.899007,<NULL-object>,"B_65x39_Caseless"]"
"T=11694.8 : [B Alpha 2-2:1,"",0.346781,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11694.8 : [B Alpha 2-2:1,"",1.19727,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"
"T=11694.8 : [B Alpha 2-2:1,"head",0.899007,B Alpha 1-1:1 (KK),"B_65x39_Caseless"]"

Notes:

  • Each "HandleDamage" event shows the current damage from the damage source, NOT cumulative or the current "damage level" (health) of the target unit.
  • Multiple "HandleDamage" event handlers can be added to the same unit, however only the damage return value from the last added EH will be relayed to the game engine.
  • 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" 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:
// first HandleDamage event - direct damage by sabot hit onto an infantry unit
1081.55,[TargetUnit,"",6426.05,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"head_hit",441.609,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"body",333.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"hands",533.333,SourceUnit,"Sh_120_SABOT"]
1081.55,[TargetUnit,"legs",533.333,SourceUnit,"Sh_120_SABOT"]

// second HandleDamage event - indirect damage by the impact - maybe force/friction applied to the unit body
1081.59,[TargetUnit,"",2.24228,TargetUnit,""]
1081.59,[TargetUnit,"head_hit",0.89672,TargetUnit,""]
1081.59,[TargetUnit,"body",3.3113,TargetUnit,""]
1081.59,[TargetUnit,"hands",3.74862,TargetUnit,""]
1081.59,[TargetUnit,"legs",10,TargetUnit,""]

Link to explanation Celery's explanation

HandleHeal

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

arma2 1.00.gif

Passed array: [unit, healer, healercanheal]

Hit

Triggered when the unit is hit/damaged.

Is not always triggered when unit is killed by a hit.
Most of the time only the killed event handler is triggered when a unit dies from a hit.
The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.
Does not fire when a unit is set to allowDamage false.

Local. effects local.gif

Passed array: [unit, causedBy, damage]

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

HitPart

arma2oa 1.60.gif arguments global.gif effects local.gif

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

While you can add "HitPart" handler to a remote unit, the respectful addEventHandler command must be executed on the shooter's PC and will only fire on shooter's PC as well. Additionally, if the unit gets damaged by any means other than shooter's shooting, "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.

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

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

HitPart Sample output after DemoCharge explosion

Init

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

Global. Global effect EventHandler

Passed array: [unit]

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

IncomingMissile

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

Global. Global effect EventHandler

Passed array: [unit, ammo, whoFired]

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

Killed

Triggered when the unit is killed.

Local. effects local.gif

Passed array: [unit, killer]

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

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

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

And sample debug output:

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

LandedTouchDown

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

Local. effects local.gif

Passed array: [plane, airportID]

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

LandedStopped

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

Local. effects local.gif

Passed array: [plane, airportID]

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

Respawn

Triggered when a unit respawns.

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

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

Put

Triggers when a unit puts an item in a container.

arma3 0.56.gif

Passed array: [unit, container, item]

  • unit: Object - Unit to which the event handler is assigned
  • container: Object - The container into which the item was placed (vehicle, box, etc.)
  • item: String - The class name of the moved item

As of 2013-04-27 this event handler is not functioning properly http://feedback.arma3.com/view.php?id=7824

Take

Triggers when a unit takes an item from a container.

arma3 0.56.gif

Passed array: [unit, container, item]

  • unit: Object - Unit to which the event handler is assigned
  • container: Object - The container from which the item was taken (vehicle, box, etc.)
  • item: String - The class name of the taken item

As of 2013-04-27 this event handler is not functioning properly http://feedback.arma3.com/view.php?id=7824 Related: http://feedback.arma3.com/view.php?id=12834

WeaponAssembled

Triggers when weapon gets assembled.

arma2oa 1.55.gif Global. Global effect EventHandler

Passed array: [unit, weapon]

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

WeaponDisassembled

Triggers when weapon gets disassembled.

arma2oa 1.55.gif Global. Global effect EventHandler

Passed array: [unit, primaryBag, secondarybag]

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

MPHit

Triggered when the unit is hit/damaged.

Is not always triggered when unit is killed by a hit.
Most of the time only the killed event handler is triggered when a unit dies from a hit.
The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased.
Does not fire when a unit is set to allowDamage false.

arma2oa 1.55.gif Global. Global effect EventHandler

Passed array: [unit, causedBy, damage]

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


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

http://community.bistudio.com/wiki/addMPEventHandler

MPKilled

Triggered when the unit is killed.

arma2oa 1.55.gif Global. Global effect EventHandler

Passed array: [unit, killer]

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


Notes:

  • This command must be used in conjunction with the command addMPEventHandler rather than the old command used for non MP commands.
  • This event handler is triggered for a disconnecting player, if "playableAI" are disabled (by admin or description.ext), so that the playable unit dies on disconnect.

Coding advice:

Call a function from the MPKilled EH code space, rather to define the full code in there directly. The reason is the code space will be transferred over network on each event activation - so keep the data as small as possible!

//good
_unit addMPEventHandler ["MPKilled",{_this spawn MyTag_Function;}];

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

MPRespawn

Triggered when a unit respawns.

arma2oa 1.55.gif Global. Global effect EventHandler

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

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


Notes:

This event never triggers on server: [1]

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

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

PostReset

From .\functions_f\Feedback\fn_feedbackInit.sqf

//checks whether PPs were reseted by engine
BIS_EnginePPReset = false;
if (isNil {player getVariable "BIS_fnc_feedback_postResetHandler"}) then {
	player setVariable ["BIS_fnc_feedback_postResetHandler", true];
	player addeventhandler ["PostReset",{BIS_EnginePPReset = true;} ];
};

SoundPlayed

Something to do with your character making noises when injured or fatigued.