ScriptInvoker Usage – Arma Reforger
| Lou Montana (talk | contribs) m (Fix example) | Lou Montana (talk | contribs)  m (Text replacement - "\{\{GameCategory\|armaR\|Modding\|(Guidelines|Tutorials)\|([^=↵]*)\}\}" to "{{GameCategory|armaR|Modding|$2|$1}}") | ||
| Line 153: | Line 153: | ||
| {{GameCategory|armaR|Modding|Tutorials | {{GameCategory|armaR|Modding|Scripting|Tutorials}} | ||
Latest revision as of 14:32, 26 February 2025
A ScriptInvoker is an object that allows other objects to subscribe to the event it represents by registering a method. Such event can provide arguments and it is important for the subscribing methods to fit the proper method signature.
The interest of using Events is that the subscribed method is be executed only if and when a specific event occurs (e.g a fired weapon, someone leaving a vehicle, etc) - no periodical check is done, saving CPU cycles and executing exactly on event.
Usage
Signature Declaration
The ScriptInvokerVoid class used above is the "default" one used for methods without arguments. In order to provide arguments to the subscribed methods, a generic ScriptInvokerBase type must be used, e.g ScriptInvokerBase<func>.
A method signature can be declared using typedef:
And used like this:
That's it! Remember that ScriptInvokers/Event Handlers are very powerful, but dangerous tools. Be sure not to fall into any trap or loop!
