onEachFrame: Difference between revisions
Jump to navigation
Jump to search
mNo edit summary |
Lou Montana (talk | contribs) m (Text replacement - "Since {{arma3}} v1.57 a stackable version of this EH is available:" to "Since {{arma3}} v1.58 a stackable version of this EH is available:") |
||
(62 intermediate revisions by 11 users not shown) | |||
Line 1: | Line 1: | ||
{{ | {{RV|type=command | ||
| arma2oa |= | |game1= arma2oa | ||
|version1= 1.63 | |||
|1. | |game2= tkoh | ||
|version2= 1.00 | |||
| | |game3= arma3 | ||
|version3= 0.50 | |||
| | |gr1= Event Handlers | ||
| | |descr= Runs given statement every frame in an [[Scheduler#Unscheduled Environment|unscheduled environment]]. | ||
{{Feature|arma3| | |||
In order to keep compatibility between official and community content: | |||
* Since {{arma3}} v1.58 a stackable version of this EH is available: [[Arma 3: Mission Event Handlers#EachFrame|EachFrame Mission Event Handler]] | |||
* Before that, the scripted version of the event handler should be used instead (using [[BIS_fnc_addStackedEventHandler]] and [[BIS_fnc_removeStackedEventHandler]]). | |||
}} | |||
| [[ | |s1= [[onEachFrame]] statement | ||
|p1= statement: [[String]] or [[Code]] | |||
| | |r1= [[Nothing]] | ||
}} | |x1= <sqf>onEachFrame { hintSilent str getPosWorld player }; // hints position every frame</sqf> | ||
|x2= Private variables defined outside of the [[onEachFrame]] scope are not inherited: | |||
<sqf> | |||
_myVar = "bob"; | |||
MyVar = "bill"; | |||
onEachFrame { hintSilent str [_myVar, MyVar]; }; | |||
// Result: [any, "bill"] | |||
</sqf> | |||
|x3= Only one [[onEachFrame]] loop can exist at any time: | |||
<sqf> | |||
onEachFrame { player sideChat "first"; }; | |||
onEachFrame { player sideChat "second"; }; // replaces the first one | |||
onEachFrame {}; // reset to the initial state | |||
</sqf> | |||
|x4= Script suspension is not permitted within [[onEachFrame]] scope: | |||
<sqf> | |||
< | // will throw an error | ||
onEachFrame { sleep 1; }; | |||
</sqf> | |||
|x5= <sqf> | |||
onEachFrame { if (diag_frameNo mod 60 isEqualTo 0) then { /* code */ } }; // executes every 60 frames (every second @ 60 FPS, every two seconds @ 30 FPS, etc) | |||
onEachFrame { // this version is the closest to a precise 1 second tick | |||
if (isNil "TAG_LastHint") then | |||
{ | |||
TAG_LastHint = diag_tickTime; | |||
} | |||
else | |||
{ | |||
if (diag_tickTime - TAG_LastHint >= 1) then // set the duration in seconds here | |||
{ | |||
hint format ["a second has passed (%1s since game start)", diag_tickTime]; | |||
TAG_LastHint = diag_tickTime; | |||
}; | |||
}; | |||
}; | |||
</sqf> | |||
[[ | |seealso= [[diag_frameNo]] [[diag_fps]] | ||
[[ | }} | ||
Latest revision as of 19:15, 15 September 2024
Description
- Description:
- Runs given statement every frame in an unscheduled environment.
- Groups:
- Event Handlers
Syntax
- Syntax:
- onEachFrame statement
- Parameters:
- statement: String or Code
- Return Value:
- Nothing
Examples
- Example 1:
- Example 2:
- Private variables defined outside of the onEachFrame scope are not inherited:
_myVar = "bob"; MyVar = "bill"; onEachFrame { hintSilent str [_myVar, MyVar]; }; // Result: [any, "bill"]
- Example 3:
- Only one onEachFrame loop can exist at any time:
- Example 4:
- Script suspension is not permitted within onEachFrame scope:
- Example 5:
- onEachFrame { if (diag_frameNo mod 60 isEqualTo 0) then { /* code */ } }; // executes every 60 frames (every second @ 60 FPS, every two seconds @ 30 FPS, etc) onEachFrame { // this version is the closest to a precise 1 second tick if (isNil "TAG_LastHint") then { TAG_LastHint = diag_tickTime; } else { if (diag_tickTime - TAG_LastHint >= 1) then // set the duration in seconds here { hint format ["a second has passed (%1s since game start)", diag_tickTime]; TAG_LastHint = diag_tickTime; }; }; };
Additional Information
- See also:
- diag_frameNo diag_fps
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