Event Handlers – ArmA: Armed Assault
| mNo edit summary | Lou Montana (talk | contribs)  m (Text replacement - "{{Feature | Informative | " to "{{Feature|informative|") | ||
| (13 intermediate revisions by 5 users not shown) | |||
| Line 1: | Line 1: | ||
| {{TOC|side}} | |||
| Event handlers are attached to objects, and allow you to automatically execute custom code upon particular events being triggered by that object. | Event handlers are attached to objects, and allow you to automatically execute custom code upon particular events being triggered by that object. | ||
| These event handlers are added to objects using the [[addEventHandler]] command, or in the object's configuration file (see below). | These event handlers are added to objects using the [[addEventHandler]] command, or in the object's configuration file (see below). | ||
| == General MP Note == | == General MP Note == | ||
| As opposed to OFP EHs, in ArmA a respawned unit still has the EHs it had before, so it is no longer required to re-add EHs after respawning. | As opposed to OFP EHs, in ArmA a respawned unit still has the EHs it had before, so it is no longer required to re-add EHs after respawning. | ||
| == Event Handlers in Config.cpp == | == Event Handlers in Config.cpp == | ||
| Line 12: | Line 14: | ||
| Scripting can be used to add an event handler to specific object in-game. However, for custom created content, you can add event handlers to '''all''' objects of a given type by placing them in the object's config. Example: | Scripting can be used to add an event handler to specific object in-game. However, for custom created content, you can add event handlers to '''all''' objects of a given type by placing them in the object's config. Example: | ||
| < | <syntaxhighlight lang="cpp"> | ||
| class CfgVehicles | class CfgVehicles | ||
| { | { | ||
| 	//... | |||
| 	//(other config code) | |||
| 	//... | |||
| 	class myVehicle : car | |||
| 	{ | |||
| 		//... | |||
| 		//(other config code) | |||
| 		//... | |||
| 		class EventHandlers | |||
| 		{ | |||
| 			init = "_this execVM 'myscript.sqf'"; | |||
| 			fired = "_this execVM 'otherscript.sqf'"; | |||
| 		}; | |||
| 	}; | |||
| }; | }; | ||
| </ | </syntaxhighlight> | ||
| {{Feature|informative|Event handlers added in the config can '''not''' be removed using the [[removeEventHandler]] command.}} | |||
| == Other Event-Based Scripts == | == Other Event-Based Scripts == | ||
| See [[User_Interface_Event_Handlers]] for event handlers used in displays/dialogs. | See [[User_Interface_Event_Handlers]] for event handlers used in displays/dialogs. | ||
| Also see [[Event Scripts]] for special scripts that are triggered under certain global events. | Also see [[Event Scripts]] for special scripts that are triggered under certain global events. | ||
| =Event Handler List= | = Event Handler List = | ||
| == AnimChanged == | |||
| Trigerred everytime a new animation is started. | Trigerred everytime a new animation is started. | ||
| Line 48: | Line 55: | ||
| Passed array: '''[unit, anim]''' | Passed array: '''[unit, anim]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to  | * unit: [[Object]] - Object the event handler is assigned to | ||
| * anim: [[String]] - Name of the anim that started | * anim: [[String]] - Name of the anim that started | ||
| == AnimDone == | == AnimDone == | ||
| Trigerred everytime an animation is finished. | Trigerred everytime an animation is finished. | ||
| Line 58: | Line 67: | ||
| Passed array: '''[unit, anim]''' | Passed array: '''[unit, anim]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to  | * unit: [[Object]] - Object the event handler is assigned to | ||
| * anim: [[String]] - Name of the anim that has been finished | * anim: [[String]] - Name of the anim that has been finished | ||
| == Dammaged == | |||
| Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP. <br> | |||
| (Does not fire if damage is set via [[setDammage]].) | |||
| (If simultaneous damage occured (e.g. via grenade) EH might be triggered several times.) | (If simultaneous damage occured (e.g. via grenade) EH might be triggered several times.) | ||
| Global. | |||
| Passed array: '''[unit, selectionName, damage]''' | Passed array: '''[unit, selectionName, damage]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to  | * unit: [[Object]] - Object the event handler is assigned to | ||
| * selectionName: [[String]] - Name of the selection where the unit was damaged | * selectionName: [[String]] - Name of the selection where the unit was damaged | ||
| * damage: [[Number]] - Resulting level of damage | * damage: [[Number]] - Resulting level of damage | ||
| == Engine ==   | |||
| == Engine == | |||
| Triggered when the engine of the unit is turned on/off. | Triggered when the engine of the unit is turned on/off. | ||
| Line 81: | Line 94: | ||
| Passed array: '''[vehicle, engineState]''' | Passed array: '''[vehicle, engineState]''' | ||
| * vehicle: [[Object]] - Vehicle the event handler is assigned to <br  | * vehicle: [[Object]] - Vehicle the event handler is assigned to <br> | ||
| * engineState: [[Boolean]] - True when the engine is turned on, false when turned off | * engineState: [[Boolean]] - True when the engine is turned on, false when turned off | ||
| ==Fired==   | |||
| == Fired == | |||
| Triggered when the unit fires a weapon.<br> | Triggered when the unit fires a weapon.<br> | ||
| This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle. | This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle. | ||
| Global.   | Global. | ||
| Passed array: '''[unit, weapon, muzzle, mode, ammo]''' | Passed array: '''[unit, weapon, muzzle, mode, ammo]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to <br  | * unit: [[Object]] - Object the event handler is assigned to <br> | ||
| * weapon: [[String]] - Fired weapon <br  | * weapon: [[String]] - Fired weapon <br> | ||
| * muzzle: [[String]] - Muzzle that was used <br  | * muzzle: [[String]] - Muzzle that was used <br> | ||
| * mode: [[String]] - Current mode of the fired weapon<br  | * mode: [[String]] - Current mode of the fired weapon<br> | ||
| * ammo: [[String]] - Ammo used | * ammo: [[String]] - Ammo used | ||
| ==Fuel==   | |||
| == Fuel == | |||
| Triggered when the unit's fuel status changes between completely empty / not empty (only useful if the event handler is assigned to a vehicle). | Triggered when the unit's fuel status changes between completely empty / not empty (only useful if the event handler is assigned to a vehicle). | ||
| Global.   | Global. | ||
| Passed array: '''[vehicle, fuelState]''' | Passed array: '''[vehicle, fuelState]''' | ||
| * vehicle: [[Object]] - Vehicle the event handler is assigned to <br  | * vehicle: [[Object]] - Vehicle the event handler is assigned to <br> | ||
| * fuelState: [[Boolean]] -  | * fuelState: [[Boolean]] - [[false]] when no fuel, [[true]] 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"). | 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. | ||
| Passed array: '''[vehicle, gearState]''' | Passed array: '''[vehicle, gearState]''' | ||
| * vehicle: [[Object]] - Vehicle the event handler is assigned to <br  | * vehicle: [[Object]] - Vehicle the event handler is assigned to <br> | ||
| * gearState: [[Boolean]] - True when the gear is lowered, false when retracted | * gearState: [[Boolean]] - True when the gear is lowered, false when retracted | ||
| ==GetIn==   | == GetIn == | ||
| Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands. | Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands. | ||
| Global.   | Global. | ||
| Passed array: '''[vehicle, position, unit]''' | Passed array: '''[vehicle, position, unit]''' | ||
| Line 131: | Line 150: | ||
| * unit: [[Object]] - Unit that entered the vehicle | * unit: [[Object]] - Unit that entered the vehicle | ||
| ==GetOut==   | |||
| == GetOut == | |||
| Triggered when a unit gets out from the object, works the same way as GetIn. | Triggered when a unit gets out from the object, works the same way as GetIn. | ||
| Global.   | Global. | ||
| == Hit == | |||
| Local.   | Triggered when the unit is hit/damaged. | ||
| Is ''not'' always triggered when unit is killed by a hit.<br> | |||
| Most of the time only the [[ArmA:_Event_Handlers#Killed|killed]] event handler is triggered when a unit dies from a hit.<br> | |||
| The hit EH will not necessarily fire if only minor damage occurred (e.g. firing a bullet at a tank), even though the damage increased. | |||
| Local. | |||
| Passed array: '''[unit, causedBy, damage]''' | Passed array: '''[unit, causedBy, damage]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to <br  | * unit: [[Object]] - Object the event handler is assigned to <br> | ||
| * causedBy: [[Object]] - Object that caused the damage.<br  | * causedBy: [[Object]] - Object that caused the damage.<br>Contains the unit itself in case of collisions. <br> | ||
| * damage: [[Number]] - Level of damage caused by the hit | * damage: [[Number]] - Level of damage caused by the hit | ||
| ==Init==   | |||
| == Init == | |||
| Triggered on mission start or when a vehicle is created on the fly using [[createVehicle]]. | Triggered on mission start or when a vehicle is created on the fly using [[createVehicle]]. | ||
| Global.   | Global. | ||
| Passed array: '''[unit]''' | Passed array: '''[unit]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to   | * unit: [[Object]] - Object the event handler is assigned to | ||
| == IncomingMissile == | |||
| Triggered when a guided missile locked on the target or unguided missile or rocket aimed by AI at the target was fired. | Triggered when a guided missile locked on the target or unguided missile or rocket aimed by AI at the target was fired. | ||
| Global.   | Global. | ||
| Passed array: '''[unit, ammo, whoFired]''' | Passed array: '''[unit, ammo, whoFired]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to <br  | * unit: [[Object]] - Object the event handler is assigned to <br> | ||
| * ammo: [[String]] - Ammo type that was fired on the unit <br  | * ammo: [[String]] - Ammo type that was fired on the unit <br> | ||
| * whoFired: [[Object]] - Object that fired the weapon | * whoFired: [[Object]] - Object that fired the weapon | ||
| ==Killed==   | |||
| == Killed == | |||
| Triggered when the unit is killed. | Triggered when the unit is killed. | ||
| Local.   | Local. | ||
| Passed array: '''[unit, killer]''' | Passed array: '''[unit, killer]''' | ||
| * unit: [[Object]] - Object the event handler is assigned to <br  | * unit: [[Object]] - Object the event handler is assigned to <br> | ||
| * killer: [[Object]] - Object that killed the unit<br  | * killer: [[Object]] - Object that killed the unit<br>Contains the unit itself in case of collisions. <br> | ||
| ==LandedTouchDown==   | == LandedTouchDown == | ||
| Triggered when a plane (AI or player) touches the ground. | Triggered when a plane (AI or player) touches the ground. | ||
| Line 188: | Line 219: | ||
| Passed array: '''[plane, airportID]''' | Passed array: '''[plane, airportID]''' | ||
| * plane: [[Object]] - Object the event handler is assigned to <br  | * plane: [[Object]] - Object the event handler is assigned to <br> | ||
| * airportID: [[Number]] - ID of the airport (-1 for anything else). <br  | * airportID: [[Number]] - ID of the airport (-1 for anything else). <br> | ||
| == LandedStopped == | |||
| Triggered when an AI pilot would get out usually. Not executed for player. | Triggered when an AI pilot would get out usually. Not executed for player. | ||
| Line 198: | Line 231: | ||
| Passed array: '''[plane, airportID]''' | Passed array: '''[plane, airportID]''' | ||
| * plane: [[Object]] - Object the event handler is assigned to <br  | * plane: [[Object]] - Object the event handler is assigned to <br> | ||
| * airportID: [[Number]] - ID of the airport (-1 for anything else). <br  | * airportID: [[Number]] - ID of the airport (-1 for anything else). <br> | ||
| [[Category: Event Handlers]] | [[Category: Event Handlers|Arma 1:Event Handlers]] | ||
| {{GameCategory|arma1|Editing}} | |||
Latest revision as of 22:41, 16 May 2024
Event handlers are attached to objects, and allow you to automatically execute custom code upon particular events being triggered by that object.
These event handlers are added to objects using the addEventHandler command, or in the object's configuration file (see below).
General MP Note
As opposed to OFP EHs, in ArmA a respawned unit still has the EHs it had before, so it is no longer required to re-add EHs after respawning.
Event Handlers in Config.cpp
Scripting can be used to add an event handler to specific object in-game. However, for custom created content, you can add event handlers to all objects of a given type by placing them in the object's config. Example:
class CfgVehicles
{
	//...
	//(other config code)
	//...
	class myVehicle : car
	{
		//...
		//(other config code)
		//...
		class EventHandlers
		{
			init = "_this execVM 'myscript.sqf'";
			fired = "_this execVM 'otherscript.sqf'";
		};
	};
};
Other Event-Based Scripts
See User_Interface_Event_Handlers for event handlers used in displays/dialogs.
Also see Event Scripts for special scripts that are triggered under certain global events.
Event Handler List
AnimChanged
Trigerred everytime a new animation is started.
Global.
Passed array: [unit, anim]
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
Dammaged
Triggered when the unit is damaged. In ArmA works with all vehicles not only men like in OFP. 
(Does not fire if damage is set via setDammage.)
(If simultaneous damage occured (e.g. via grenade) EH might be triggered several times.)
Global.
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.
Passed array: [vehicle, engineState]
- vehicle: Object - Vehicle the event handler is assigned to 
- engineState: Boolean - True when the engine is turned on, false when turned off
Fired
Triggered when the unit fires a weapon.
This EH will not trigger if a unit fires out of a vehicle. For those cases an EH has to be attached to that particular vehicle.
Global.
Passed array: [unit, weapon, muzzle, mode, ammo]
- 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
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.
Passed array: [vehicle, fuelState]
- vehicle: Object - Vehicle the event handler is assigned to 
- fuelState: Boolean - false when no fuel, true 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.
Passed array: [vehicle, gearState]
- vehicle: Object - Vehicle the event handler is assigned to 
- gearState: Boolean - True when the gear is lowered, false when retracted
GetIn
Triggered when a unit enters the object (only useful when the event handler is assigned to a vehicle). It does not trigger upon a change of positions within the same vehicle. It also is not triggered by the moveInX commands.
Global.
Passed array: [vehicle, position, unit]
- vehicle: Object - Vehicle the event handler is assigned to
- position: String - Can be either "driver", "gunner", "commander" or "cargo"
- unit: Object - Unit that entered the vehicle
GetOut
Triggered when a unit gets out from the object, works the same way as GetIn.
Global.
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.
Local.
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
Init
Triggered on mission start or when a vehicle is created on the fly using createVehicle.
Global.
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.
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.
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.
LandedTouchDown
Triggered when a plane (AI or player) touches the ground.
Local.
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.
Passed array: [plane, airportID]
