safeZoneH: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Text replacement - "<tt>([^ ]*=[^ ]*)<\/tt>" to "{{hl|c= $1}}")
m (Text replacement - "[[Image:" to "[[File:")
(31 intermediate revisions by the same user not shown)
Line 15: Line 15:
|gr1= GUI Control - Positioning
|gr1= GUI Control - Positioning


|descr= Returns the height of the screen in screen measurement units. Taken from top left corner of the default viewport (0,0) of the screen and going in the same direction as the Y axis, the value will be positive but resulting Y will end up beyond the bottom border. Therefore in order to calculate Y of the bottom screen border, the length of [[safeZoneY]] must be subtracted from [[safeZoneH]], but because it is negative, it must be added instead. {{hl|c= _screenBottomBorderY <nowiki>=</nowiki> [[safeZoneH]] + [[safeZoneY]]}}. The measurement units depend on the current screen resolution [[getResolution]]. See also [[SafeZone]]
|descr= [[File:safezone.jpg|right|600px]]
[[Image:safezone.jpg|600px]]
Returns the height of the screen in screen measurement units.
Taken from top left corner of the default viewport (0,0) of the screen and going in the same direction as the Y axis, the value will be positive but resulting Y will end up beyond the bottom border.
Therefore in order to calculate Y of the bottom screen border, the length of [[safeZoneY]] must be subtracted from [[safeZoneH]], but because it is negative, it must be added instead.
<sqf inline>_screenBottomBorderY = safeZoneH + safeZoneY</sqf>. The measurement units depend on the current screen resolution [[getResolution]]. See also [[SafeZone]].


|s1= [[safeZoneH]]
|s1= [[safeZoneH]]


|r1= [[Number]] - Height of the screen in screen measurement units
|r1= [[Number]] - height of the screen in screen measurement units


|x1= <code>_screenHeight = [[safeZoneH]];</code>
|x1= <sqf>_screenHeight = safeZoneH;</sqf>


|x2= <code>_screenTopBorderY = [[safeZoneY]];
|x2= <sqf>_screenTopBorderY = safeZoneY;
_screenBottomBorderY = [[safeZoneH]] + [[safeZoneY]];</code>
_screenBottomBorderY = safeZoneH + safeZoneY;</sqf>


|x3= Create control 50% wide, 30% tall, centered on screen:<code>[[private]] _ctrl = [[findDisplay]] 46 [[createDisplay]] "RscDisplayEmpty" [[ctrlCreate]] ["RscText", -1];
|x3= Create control 50% wide, 30% tall, centered on screen:
_ctrl [[ctrlSetBackgroundColor]] [1,0,0,0.5];
<sqf>
[[private]] _ctrlWidth = 0.5 * [[safeZoneW]]; // 50% of screen width
private _ctrl = findDisplay 46 createDisplay "RscDisplayEmpty" ctrlCreate ["RscText", -1];
[[private]] _ctrlHeight = 0.3 * [[safeZoneH]]; // 30% of screen height
_ctrl ctrlSetBackgroundColor [1,0,0,0.5];
_ctrl [[ctrlSetPositionW]] _ctrlWidth;
private _ctrlWidth = 0.5 * safeZoneW; // 50% of screen width
_ctrl [[ctrlSetPositionH]] _ctrlHeight;
private _ctrlHeight = 0.3 * safeZoneH; // 30% of screen height
_ctrl [[ctrlSetPositionX]] (([[safeZoneW]] - _ctrlWidth) / 2 + [[safeZoneX]]); // center it horizontally
_ctrl ctrlSetPositionW _ctrlWidth;
_ctrl [[ctrlSetPositionY]] (([[safeZoneH]] - _ctrlHeight) / 2 + [[safeZoneY]]); // center it vertically
_ctrl ctrlSetPositionH _ctrlHeight;
_ctrl [[ctrlCommit]] 0;</code>
_ctrl ctrlSetPositionX ((safeZoneW - _ctrlWidth) / 2 + safeZoneX); // center it horizontally
_ctrl ctrlSetPositionY ((safeZoneH - _ctrlHeight) / 2 + safeZoneY); // center it vertically
_ctrl ctrlCommit 0;
</sqf>


|seealso= [[SafeZone]], [[safeZoneX]], [[safeZoneY]], [[safeZoneW]], [[safeZoneXAbs]], [[safeZoneWAbs]]
|seealso= [[SafeZone]] [[safeZoneX]] [[safeZoneY]] [[safeZoneW]] [[safeZoneXAbs]] [[safeZoneWAbs]]
}}
}}

Revision as of 23:10, 20 November 2023

Hover & click on the images for description

Description

Description:
safezone.jpg

Returns the height of the screen in screen measurement units. Taken from top left corner of the default viewport (0,0) of the screen and going in the same direction as the Y axis, the value will be positive but resulting Y will end up beyond the bottom border. Therefore in order to calculate Y of the bottom screen border, the length of safeZoneY must be subtracted from safeZoneH, but because it is negative, it must be added instead.

_screenBottomBorderY = safeZoneH + safeZoneY. The measurement units depend on the current screen resolution getResolution. See also SafeZone.
Groups:
GUI Control - Positioning

Syntax

Syntax:
safeZoneH
Return Value:
Number - height of the screen in screen measurement units

Examples

Example 1:
_screenHeight = safeZoneH;
Example 2:
_screenTopBorderY = safeZoneY; _screenBottomBorderY = safeZoneH + safeZoneY;
Example 3:
Create control 50% wide, 30% tall, centered on screen:
private _ctrl = findDisplay 46 createDisplay "RscDisplayEmpty" ctrlCreate ["RscText", -1]; _ctrl ctrlSetBackgroundColor [1,0,0,0.5]; private _ctrlWidth = 0.5 * safeZoneW; // 50% of screen width private _ctrlHeight = 0.3 * safeZoneH; // 30% of screen height _ctrl ctrlSetPositionW _ctrlWidth; _ctrl ctrlSetPositionH _ctrlHeight; _ctrl ctrlSetPositionX ((safeZoneW - _ctrlWidth) / 2 + safeZoneX); // center it horizontally _ctrl ctrlSetPositionY ((safeZoneH - _ctrlHeight) / 2 + safeZoneY); // center it vertically _ctrl ctrlCommit 0;

Additional Information

See also:
SafeZone safeZoneX safeZoneY safeZoneW safeZoneXAbs safeZoneWAbs

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