getResolution: Difference between revisions

From Bohemia Interactive Community
m (Text replacement - "\|seealso= *\[\[([^ ]+)\]\], \[\[([^ ]+)\]\]" to "|seealso= $1 $2")
m (Text replacement - "\{\{Feature *\| *Informative *\| ([^↵]+) *\}\}" to "{{Feature|informative|$1}}")
 
(8 intermediate revisions by 3 users not shown)
Line 16: Line 16:
|descr= Returns an array containing all information about current client screen resolution.
|descr= Returns an array containing all information about current client screen resolution.


{{Feature | arma3 | '''Render resolution''' is not returned by this command.<br>
{{Feature|arma3|
'''Render resolution''' is not returned by this command.<br>
A sampling setting of '''50%''' means half of native width ''and'' half of native height, resulting in a render resolution of '''''25%''''' the original resolution.}}
A sampling setting of '''50%''' means half of native width ''and'' half of native height, resulting in a render resolution of '''''25%''''' the original resolution.}}
{{Feature | important | The engine default value for {{hl|fovTop}} is '''0.75''' in case it is needed to calculate difference with custom FOV.}}
{{Feature | important | The engine default value for {{hl|fovTop}} is '''0.75''' in case it is needed to calculate difference with custom FOV.}}
{{Feature | Informative | The {{hl|aspectRatio}} is calculated as {{hl|fovLeft&nbsp;/&nbsp;fovTop}} and should be the same as {{hl|screenW&nbsp;/&nbsp;screenH}} for undistorted image if the FOV is custom. Some of the common values:
{{Feature|informative|The {{hl|aspectRatio}} is calculated as {{hl|fovLeft&nbsp;/&nbsp;fovTop}} and should be the same as {{hl|screenW&nbsp;/&nbsp;screenH}} for undistorted image if the FOV is custom. Some of the common values:
{{{!}} class{{=}}"wikitable"
{{{!}} class{{=}}"wikitable"
! 16/9 !! 16/10 !! 5/4 !! 4/3 !! 16/9 triple screen
! 16/9 !! 16/10 !! 5/4 !! 4/3 !! 16/9 triple screen
Line 29: Line 30:
|s1= [[getResolution]]
|s1= [[getResolution]]


|r1= [[Array]] - {{hl|[screenW, screenH, viewPortW, viewPortH, aspectRatio, uiScale, fovTop, fovLeft, tripleHead]}}<br>
|r1= [[Array]] - {{hl|[screenW, screenH, viewPortW, viewPortH, aspectRatio, uiScale, fovTop, fovLeft, tripleHead, textureQuality]}}
* {{hl|screenW}}: [[Number]] - width of the screen in pixels
* {{hl|screenW}}: [[Number]] - width of the screen in pixels
* {{hl|screenH}}: [[Number]] - height of the screen in pixels
* {{hl|screenH}}: [[Number]] - height of the screen in pixels
Line 36: Line 37:
* {{hl|aspectRatio}}: [[Number]] - screen aspect ratio
* {{hl|aspectRatio}}: [[Number]] - screen aspect ratio
* {{hl|uiScale}}: [[Number]] - the scale of the UI, which affects view port size:
* {{hl|uiScale}}: [[Number]] - the scale of the UI, which affects view port size:
: {{{!}} class{{=}}"wikitable" style{{=}}"margin-top: -0.5em"
: {{{!}} class="wikitable" style="margin-top: -0.5em"
{{!}}+ Arma 3
{{!}}+ {{arma3}}
! Very Small !! Small !! Normal !! Large !! Very Large
! Very Small !! Small !! Normal !! Large !! Very Large
{{!}}-
{{!}}-
{{!}} 0.47 {{!}}{{!}} 0.55 {{!}}{{!}} 0.7 {{!}}{{!}} 0.85 {{!}}{{!}} 1
{{!}} 0.47 {{!}}{{!}} 0.55 {{!}}{{!}} 0.7 {{!}}{{!}} 0.85 {{!}}{{!}} 1
{{!}}}
{{!}}}
* {{hl|fovTop}}: [[Number]] - vertical FOV in [[rad | radians]], the same as {{hl|fovTop}} value from the user profile (since {{arma3}} v1.94)
* {{GVI|arma3|1.94|size= 0.75}} {{hl|fovTop}}: [[Number]] - vertical FOV in [[rad]]ians, the same as {{hl|fovTop}} value from the user profile
* {{hl|fovLeft}}: [[Number]] - horizontal FOV in [[rad | radians]], the same as{{hl|fovLeft}} value from the user profile (since {{arma3}} v1.94)
* {{GVI|arma3|1.94|size= 0.75}} {{hl|fovLeft}}: [[Number]] - horizontal FOV in [[rad]]ians, the same as{{hl|fovLeft}} value from the user profile
* {{hl|tripleHead}}: [[Boolean]] - [[true]] if user has triple head screen (see also [[safeZoneXAbs]], [[safeZoneWAbs]]) (since {{arma3}} v1.94)
* {{GVI|arma3|1.94|size= 0.75}} {{hl|tripleHead}}: [[Boolean]] - [[true]] if user has triple head screen (see also [[safeZoneXAbs]], [[safeZoneWAbs]])
* {{GVI|arma3|2.10|size= 0.75}} {{hl|textureQuality}}: [[Number]] - current texture quality set in user preferences in 0..1 range, where 0 is lowest, 1 is highest


|x1= <code>_res = [[getResolution]]; {{cc|a 16/9 single monitor setup}}</code>
|x1= <sqf>private _res = getResolution;</sqf>
<code>[
1360, {{cc|width}}
768, {{cc|height}}
867, {{cc|2D viewport width}}
653, {{cc|2D viewport height}}
1.77778, {{cc|aspect ratio}}
0.85 {{cc|UI scale}}
]</code>
|x2= <code>_res = [[getResolution]];  {{cc|dedicated server}}</code>
<code>[
160, {{cc|width}}
120, {{cc|height}}
136, {{cc|2D viewport width}}
102, {{cc|2D viewport height}}
1.33333, {{cc|aspect ratio}}
0.85 {{cc|UI scale}}
]</code>
|x3= <code>_res = [[getResolution]]; {{cc|a triple 16/9 monitor setup}}</code>
<code>[
5760, {{cc|width}}
1080, {{cc|height}}
792, {{cc|2D viewport width}}
594, {{cc|2D viewport height}}
5.33333, {{cc|aspect ratio}}
0.55 {{cc|UI scale}}
]</code>


|x4= <code>_res = [[getResolution]]; {{cc|16/9 monitor setup}}</code>
Example result with a single 16:9 monitor:
<code>[
<sqf>
1920, {{cc|width}}
[
1080, {{cc|height}}
1920, // width
792, {{cc|2D viewport width}}
1080, // height
594, {{cc|2D viewport height}}
792, // 2D viewport width
1.77778, {{cc|aspect ratio}}
594, // 2D viewport height
0.55, {{cc|UI scale}}
1.77778, // aspect ratio
0.75, {{cc|fovTop}}
0.55, // UI scale
1.33333, {{cc|fovLeft}}
0.75, // fovTop
false {{cc|tripleHead}}
1.33333, // fovLeft
]</code>
false // tripleHead
]
</sqf>
Example result with a triple 16:9 monitor setup:
<sqf>
[
5760, // width
1080, // height
792, // 2D viewport width
594, // 2D viewport height
5.33333, // aspect ratio
0.55 // UI scale
]
</sqf>
Example result on a dedicated server:
<sqf>
[
160, // width
120, // height
136, // 2D viewport width
102, // 2D viewport height
1.33333, // aspect ratio
0.85 // UI scale
]
</sqf>


|seealso= [[getObjectFOV]] [[worldToScreen]] [[screenToWorld]] [[safeZoneX]] [[safeZoneY]] [[safeZoneW]], [[safeZoneH]]
|seealso= [[getObjectFOV]] [[worldToScreen]] [[screenToWorld]] [[safeZoneX]] [[safeZoneY]] [[safeZoneW]] [[safeZoneH]]
}}
}}


<dl class="command_description">
{{Note
 
|user= Tom_48_97
<dt></dt>
|timestamp= 20101220053800
<dd class="notedate">Posted on  05:38, 20 December 2010</dd>
|text= This command can be useful to play a video (see this function [[BIS_fnc_playVideo]]) in the given format if you have compiled it for different UI scale.
<dt class="note">[[User:Tom 48 97|tom_48_97]]</dt>
}}
<dd class="note">This command can be useful to play a video (see this function [[BIS_fnc_playVideo]]) in the given format if you have compiled it for different UI scale.</dd>
 
</dl>

Latest revision as of 18:11, 15 March 2024

Hover & click on the images for description

Description

Description:
Returns an array containing all information about current client screen resolution.
Arma 3
Render resolution is not returned by this command.
A sampling setting of 50% means half of native width and half of native height, resulting in a render resolution of 25% the original resolution.
The engine default value for fovTop is 0.75 in case it is needed to calculate difference with custom FOV.
The aspectRatio is calculated as fovLeft / fovTop and should be the same as screenW / screenH for undistorted image if the FOV is custom. Some of the common values:
16/9 16/10 5/4 4/3 16/9 triple screen
1.777777(…) 1.6 1.25 1.333333(…) 5.333333(…)
Groups:
SystemGUI Control - Positioning

Syntax

Syntax:
getResolution
Return Value:
Array - [screenW, screenH, viewPortW, viewPortH, aspectRatio, uiScale, fovTop, fovLeft, tripleHead, textureQuality]
  • screenW: Number - width of the screen in pixels
  • screenH: Number - height of the screen in pixels
  • viewPortW: Number - width of the 4:3 view port in pixels
  • viewPortH: Number - height of the 4:3 view port in pixels
  • aspectRatio: Number - screen aspect ratio
  • uiScale: Number - the scale of the UI, which affects view port size:
Arma 3
Very Small Small Normal Large Very Large
0.47 0.55 0.7 0.85 1

Examples

Example 1:
private _res = getResolution;
Example result with a single 16:9 monitor:
[ 1920, // width 1080, // height 792, // 2D viewport width 594, // 2D viewport height 1.77778, // aspect ratio 0.55, // UI scale 0.75, // fovTop 1.33333, // fovLeft false // tripleHead ]
Example result with a triple 16:9 monitor setup:
[ 5760, // width 1080, // height 792, // 2D viewport width 594, // 2D viewport height 5.33333, // aspect ratio 0.55 // UI scale ]
Example result on a dedicated server:
[ 160, // width 120, // height 136, // 2D viewport width 102, // 2D viewport height 1.33333, // aspect ratio 0.85 // UI scale ]

Additional Information

See also:
getObjectFOV worldToScreen screenToWorld safeZoneX safeZoneY safeZoneW safeZoneH

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
Tom_48_97 - c
Posted on Dec 20, 2010 - 05:38 (UTC)
This command can be useful to play a video (see this function BIS_fnc_playVideo) in the given format if you have compiled it for different UI scale.