getResolution: Difference between revisions

From Bohemia Interactive Community
(fov top, fov left, triple head, description, example)
m (Text replacement - "\{\{Feature *\| *Informative *\| ([^↵]+) *\}\}" to "{{Feature|informative|$1}}")
 
(46 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{Command|Comments=
{{RV|type=command
____________________________________________________________________________________________


| arma2oa |Game name=
|game1= arma2oa
|version1= 1.55


|1.55|Game version=
|game2= tkoh
____________________________________________________________________________________________
|version2= 1.00


| Returns an array containing all information about current client screen resolution in format:<br>
|game3= arma3
<tt>[screenW, screenH, viewPortW, viewPortH, aspectRatio, uiScale, fovTop, fovLeft, trippleHead]</tt>
|version3= 0.50
<br>Where:
 
* <tt>screenW</tt> [[Number]]: width of the screen in pixels
|gr1= System
* <tt>screenH</tt> [[Number]]: height of the screen in pixels
 
* <tt>viewPortW</tt> [[Number]]: width of the 4:3 view port in pixels
|gr2= GUI Control - Positioning
* <tt>viewPortH</tt> [[Number]]: height of the 4:3 view port in pixels
 
* <tt>aspectRatio</tt> [[Number]]: screen aspect ratio
|descr= Returns an array containing all information about current client screen resolution.
* <tt>uiScale</tt> [[Number]]: the scale of the UI, which affects view port size, is currently (Arma 3):<br>
 
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<tt>0.47 - Very Small</tt><br>
{{Feature|arma3|
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<tt>0.55 - Small</tt><br>
'''Render resolution''' is not returned by this command.<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<tt>0.7 - Normal</tt><br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<tt>0.85 - Large</tt><br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;<tt>1 - Very Large</tt><br>
* <tt>fovTop</tt> [[Number]]: vertical FOV in [[rad | radians]], the same as <tt>fovTop</tt> value from the user profile (''Since Arma 3 v1.94.145947'')
* <tt>fovLeft</tt> [[Number]]: horizontal FOV in [[rad | radians]], the same as<tt>fovLeft</tt> value from the user profile (''Since Arma 3 v1.94.145947'')
* <tt>trippleHead</tt> [[Boolean]]: [[true]] if user has triple head screen (see also [[safeZoneXAbs]], [[safeZoneWAbs]]) (''Since Arma 3 v1.94.145947'')<br><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.}}
{{Important | The engine default value for <tt>fovTop</tt> is <b>0.75</b> 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.}}
{{Informative| The <tt>aspectRatio</tt> is calculated as <tt>fovLeft / fovTop</tt> and should be the same as <tt>screenW / screenH</tt> 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:
* 16/9 {{=}} 1.777777(…)
{{{!}} class{{=}}"wikitable"
* 16/10 {{=}} 1.6
! 16/9 !! 16/10 !! 5/4 !! 4/3 !! 16/9 triple screen
* 5/4 {{=}} 1.25
{{!}}-
* 4/3 {{=}} 1.333333(…)
{{!}} 1.777777(…) {{!}}{{!}} 1.6 {{!}}{{!}} 1.25 {{!}}{{!}} 1.333333(…) {{!}}{{!}} 5.333333(…)
* triple screen 16/9 {{=}} 5.333333(…)}}
{{!}}}
|Description=
}}
____________________________________________________________________________________________


| [[getResolution]] |Syntax=
|s1= [[getResolution]]


| [[Array]] - see the description|Return value=
|r1= [[Array]] - {{hl|[screenW, screenH, viewPortW, viewPortH, aspectRatio, uiScale, fovTop, fovLeft, tripleHead, textureQuality]}}
____________________________________________________________________________________________
* {{hl|screenW}}: [[Number]] - width of the screen in pixels
* {{hl|screenH}}: [[Number]] - height of the screen in pixels
* {{hl|viewPortW}}: [[Number]] - width of the '''4:3''' view port in pixels
* {{hl|viewPortH}}: [[Number]] - height of the '''4:3''' view port in pixels
* {{hl|aspectRatio}}: [[Number]] - screen aspect ratio
* {{hl|uiScale}}: [[Number]] - the scale of the UI, which affects view port size:
: {{{!}} class="wikitable" style="margin-top: -0.5em"
{{!}}+ {{arma3}}
! Very Small !! Small !! Normal !! Large !! Very Large
{{!}}-
{{!}} 0.47 {{!}}{{!}} 0.55 {{!}}{{!}} 0.7 {{!}}{{!}} 0.85 {{!}}{{!}} 1
{{!}}}
* {{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
* {{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
* {{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]]; {{codecomment|// a 16/9 single monitor setup}}</code>
|x1= <sqf>private _res = getResolution;</sqf>
<code>[
1360, {{codecomment|// width}}
768, {{codecomment|// height}}
867, {{codecomment|// 2D viewport width}}
653, {{codecomment|// 2D viewport height}}
1.77778, {{codecomment|// aspect ratio}}
0.85 {{codecomment|// UI scale}}
]</code> |Example 1=
|x2= <code>_res = [[getResolution]];  {{codecomment|// dedicated server}}</code>
<code>[
160, {{codecomment|// width}}
120, {{codecomment|// height}}
136, {{codecomment|// 2D viewport width}}
102, {{codecomment|// 2D viewport height}}
1.33333, {{codecomment|// aspect ratio}}
0.85 {{codecomment|// UI scale}}
]</code> |Example 2=
|x3= <code>_res = [[getResolution]]; {{codecomment|// a triple 16/9 monitor setup}}</code>
<code>[
5760, {{codecomment|// width}}
1080, {{codecomment|// height}}
792, {{codecomment|// 2D viewport width}}
594, {{codecomment|// 2D viewport height}}
5.33333, {{codecomment|// aspect ratio}}
0.55 {{codecomment|// UI scale}}
]</code> |Example 3=


|x4= Since Arma 3 v1.94.145947:<code>_res = [[getResolution]]; {{codecomment|// 16/9 monitor setup}}</code>
Example result with a single 16:9 monitor:
<code>[
<sqf>
1920, {{codecomment|// width}}
[
1080, {{codecomment|// height}}
1920, // width
792, {{codecomment|// 2D viewport width}}
1080, // height
594, {{codecomment|// 2D viewport height}}
792, // 2D viewport width
1.77778, {{codecomment|// aspect ratio}}
594, // 2D viewport height
0.55, {{codecomment|// UI scale}}
1.77778, // aspect ratio
0.75, {{codecomment|// fovTop}}
0.55, // UI scale
1.33333, {{codecomment|// fovLeft}}
0.75, // fovTop
false {{codecomment|// trippleHead}}
1.33333, // fovLeft
]</code> |Example 4=
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>


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


<h3 style="display:none">Notes</h3>
{{Note
<dl class="command_description">
|user= Tom_48_97
<!-- Note Section BEGIN -->
|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>
<!-- Note Section END -->
</dl>
 
<h3 style="display:none">Bottom Section</h3>
 
[[Category:Scripting Commands|{{uc:{{PAGENAME}}}}]]
[[Category:Scripting Commands ArmA2|{{uc:{{PAGENAME}}}}]]
[[Category:ArmA 2 OA: New Scripting Commands List|{{uc:{{PAGENAME}}}}]]
[[Category:Scripting_Commands_Take_On_Helicopters|{{uc:{{PAGENAME}}}}]]
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]

Latest revision as of 19: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.