displayAddEventHandler: Difference between revisions
Jump to navigation
Jump to search
Lou Montana (talk | contribs) m (Some wiki formatting) |
Lou Montana (talk | contribs) m (Some wiki formatting) |
||
Line 19: | Line 19: | ||
|descr= Adds an event handler to the given display. See [[User Interface Event Handlers]] for the full list of event names. | |descr= Adds an event handler to the given display. See [[User Interface Event Handlers]] for the full list of event names. | ||
If applicable, see [[DIK_KeyCodes]] for a list of key code constants, which are relevant to key related user interface events like: [[User Interface Event Handlers#onKeyDown|KeyDown]] & [[User Interface Event Handlers#onKeyUp|KeyUp]]. | If applicable, see [[DIK_KeyCodes]] for a list of key code constants, which are relevant to key related user interface events like: [[User Interface Event Handlers#onKeyDown|KeyDown]] & [[User Interface Event Handlers#onKeyUp|KeyUp]]. | ||
{{Feature|important|Display EHs are processed | {{Feature|important|Display EHs are processed from last to first added; an input override should be set up in the first added EH.}} | ||
{{Feature|informative|The event handler ID can be accessed inside the event handler code using the | {{Feature|informative|The event handler ID can be accessed inside the event handler code using the <sqf inline>_thisEventHandler</sqf> [[Magic_Variables#thisEventHandler|magic variable]].}} | ||
|s1= display [[displayAddEventHandler]] | |s1= display [[displayAddEventHandler]] [eventName, code] | ||
|p1= display: [[Display]] | |p1= display: [[Display]] | ||
|p2= eventName: [[String]] - | |p2= eventName: [[String]] - event name | ||
{{Feature|important|When using the event names listed [[User Interface Event Handlers|here]] with the [[ctrlAddEventHandler]], [[ctrlSetEventHandler]], [[displayAddEventHandler]] or [[displaySetEventHandler]] commands, the prefix "on" in the event name must be removed (e.g. ''''ButtonDown'''' instead of ''''onButtonDown'''').}} | |||
|p3= code: [[String]] or [[Code]] - | |p3= code: [[String]] or {{GVI|arma3|1.06|size=0.75}} [[Code]] - the code which gets executed when event is triggered. Returning [[true]] in event handler code will override default engine handling for keyboard events. | ||
|r1= [[Number]] - | |r1= [[Number]] - index of the newly added event handler or {{hl|-1}} if creation failed | ||
|x1= <sqf>moduleName_keyDownEHId = findDisplay 46 displayAddEventHandler ["KeyDown", "hint str _this;"];</sqf> | |x1= <sqf>moduleName_keyDownEHId = findDisplay 46 displayAddEventHandler ["KeyDown", "hint str _this;"];</sqf> | ||
Line 39: | Line 40: | ||
}} | }} | ||
< | {{Note | ||
|user= Axyl | |||
|timestamp= 20140310145200 | |||
|text= From within an Addon, you must assign the events from a spawned script. e.g. <sqf>[] spawn { findDisplay 46 displayAddEventHandler ["KeyDown", "[[_this]] call my_KeyDownFunctionhandler"]; };</sqf> | |||
}} | |||
{{Note | |||
|user= Pigneedle | |||
|timestamp= 20160122081500 | |||
|text= Be sure to wait until the main display is initialized before using this command by using: | |||
Be sure to wait until the main display is initialized before using this command by using: | |||
<sqf>waitUntil { !isNull (findDisplay 46) };</sqf> | <sqf>waitUntil { !isNull (findDisplay 46) };</sqf> | ||
}} | |||
{{Note | |||
|user= IT07 | |||
|timestamp= 20170528113200 | |||
|text= use #define if you want the displayEventHandler to use data that is defined in the same file in which the command is executed. | |||
use #define if you want the displayEventHandler to use data that is defined in the same file in which the command is executed. | |||
However, that does not work if you use [[String]] as 'code'. In case of [[String]], use the format command around it. | However, that does not work if you use [[String]] as 'code'. In case of [[String]], use the format command around it. | ||
}} | |||
{{Note | |||
|user= DrSova | |||
|timestamp= 20170807150800 | |||
|text= Using '''KeyUp''' you can't override default engine action by returning '''true''' | |||
Using '''KeyUp''' you can't override default engine action by returning '''true''' | |game= arma3 | ||
|version= 1.72 | |||
}} | |||
{{Note | |||
|user= R3vo | |||
|timestamp= 20210626161700 | |||
|text= To prevent a display from getting closed by pressing ESC, add the following event handler. | |||
To prevent a display from getting closed by pressing ESC, add the following event handler. | <sqf> | ||
<sqf>#include "\a3\ui_f\hpp\definedikcodes.inc" | #include "\a3\ui_f\hpp\definedikcodes.inc" | ||
_display displayAddEventHandler ["KeyDown", | _display displayAddEventHandler ["KeyDown", | ||
{ | { | ||
params ["", "_key"]; | params ["", "_key"]; | ||
_key == DIK_ESC // ESC pressed while dialog is open, overwrite default behaviour | _key == DIK_ESC; // ESC pressed while dialog is open, overwrite default behaviour | ||
}];</sqf> | }]; | ||
</sqf> | |||
}} |
Revision as of 14:21, 27 July 2022
Description
- Description:
- Adds an event handler to the given display. See User Interface Event Handlers for the full list of event names. If applicable, see DIK_KeyCodes for a list of key code constants, which are relevant to key related user interface events like: KeyDown & KeyUp.
- Groups:
- GUI Control - Event HandlersEvent Handlers
Syntax
- Syntax:
- display displayAddEventHandler [eventName, code]
- Parameters:
- display: Display
- eventName: String - event name
- code: String or
1.06 Code - the code which gets executed when event is triggered. Returning true in event handler code will override default engine handling for keyboard events.
- Return Value:
- Number - index of the newly added event handler or -1 if creation failed
Examples
- Example 1:
- Example 2:
Additional Information
- See also:
- ListOfKeyCodes disableSerialization displayRemoveAllEventHandlers displayRemoveEventHandler displaySetEventHandler ctrlAddEventHandler UI Event Handlers findDisplay DIK KeyCodes keyName
Notes
-
Report bugs on the Feedback Tracker and/or discuss them on the Arma Discord or on the Forums.
Only post proven facts here! Add Note
- Posted on Mar 10, 2014 - 14:52 (UTC)
-
From within an Addon, you must assign the events from a spawned script. e.g. Copy[] spawn { findDisplay 46 displayAddEventHandler ["KeyDown", "[[_this]] call my_KeyDownFunctionhandler"]; };
- Posted on Jan 22, 2016 - 08:15 (UTC)
- Be sure to wait until the main display is initialized before using this command by using:
- Posted on May 28, 2017 - 11:32 (UTC)
- use #define if you want the displayEventHandler to use data that is defined in the same file in which the command is executed. However, that does not work if you use String as 'code'. In case of String, use the format command around it.
- Posted on Aug 07, 2017 - 15:08 (UTC)
-
Using KeyUp you can't override default engine action by returning true
- Posted on Jun 26, 2021 - 16:17 (UTC)
- To prevent a display from getting closed by pressing ESC, add the following event handler.