* Docs/Cargo - Include missing "unload type" param
There's a LOT of pages that are still missing documentation on listenable events entirely, maybe I'll get around to fixing that at some point.
* Update events-framework.md
Co-authored-by: PabstMirror <pabstmirror@gmail.com>
Explains how to use CBA event handlers with ACE3 events used to trigger or allow triggering of specific functionality and lists all documented events.
framework
5
wiki
ace
1. Event Handlers
Event handlers in ACE3 are implemented through CBA's Event System. They should be used to trigger or allow triggering of specific functionality.
2. Events List
ACE3 uses many events internally, this is not a complete list; but it should list most publicly usable events.
2.1 Fired Event Handlers (ace_common)
Different events for what type of unit has fired.
E.G.: If you only need to do action when player's weapon fires, this will be faster than adding an XEH for everything.
The vehicle events will also have the following local variables available _gunner (OBJECT), _turret (ARRAY).
CBA_fnc_addEventHandler - Adds an event handler with the event name and returns the event handler ID.
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Code block
Code
Required
R
Event ID
Number
Return value
3.1.2 Remove Event
CBA_fnc_removeEventHandler - Removes a specific event handler of the given event name, using the ID returned from CBA_fnc_addEventHandler.
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Event ID
Number
Required
R
None
None
Return value
3.2 Calling Events
3.2.1 Local Event
CBA_fnc_localEvent - Calls an event only on the local machine, useful for inter-module events.
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Arguments
Any
Required
R
None
None
Return value
3.2.2 Target Event
CBA_fnc_targetEvent - Calls an event only on the target machine or list of target machines.
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Arguments
Any
Required
2
Target(s)
Object OR Number OR Array
Required
R
None
None
Return value
3.2.3 Server Event
CBA_fnc_serverEvent - Calls an event only on the server machine (dedicated or self-hosted).
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Arguments
Any
Required
R
None
None
Return value
3.2.4 Global Event
CBA_fnc_globalEvent - Calls an event on all machines - the local machine, and the server machine.
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Arguments
Any
Required
R
None
None
Return value
3.3 Synchronized Events
3.3.1 Add Synchronized Event
Adds a globally synchronized event handler which will expire events after the provided time-to-live, or the code returns true.
ace_common_fnc_addSyncedEventHandler
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Code block
Code
Required
2
Time to live
Number OR Code
Optional (default: 0)
R
Event ID
Number
Return value
3.3.2 Remove Synchronized Event
Removes a specific event handler of the given event name, using the ID returned from ace_common_fnc_addSyncedEventHandler.
ace_common_fnc_removeSyncedEventHandler
Arguments
Type
Optional (default value)
0
Event name
String
Required
R
None
None
Return value
3.3.3 Call Synchronized Event
Calls a globally synchronized event, which will also be run on JIP players unless it has expired. Event will expire after the provided time-to-live, or the code returns true.
ace_common_fnc_syncedEvent
Arguments
Type
Optional (default value)
0
Event name
String
Required
1
Arguments
Any
Required
2
Time to live for this call
Number OR Code
Optional (default: 0)
R
Event ID
Number
Return value
3.4 Example
// Event handler added on a target machine
["ace_interact_tapShoulder", ace_example_fnc_onTapShoulder] call CBA_fnc_addEventHandler;
// Event called on another machine (tapping above target machine)
["ace_interact_tapShoulder", [arguments], [target]] call CBA_fnc_targetEvent;