getTextWidth: Difference between revisions

From Bohemia Interactive Community
Jump to navigation Jump to search
m (Added 2nd command group)
m (Text replacement - "↵↵</sqf>" to " </sqf>")
 
(79 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{Command|Comments=
{{RV|type=command
____________________________________________________________________________________________


| arma3 |Game name=
|game1= arma3
|version1= 1.98


|1.98|Game version=
|gr1= GUI Control


|gr1= GUI Control |GROUP1=
|gr2= Strings


|gr2= Strings |GROUP2=
|descr= Returns estimated width of the text based on [[FXY_File_Format#Available_Fonts|font type]] and size. Similar to [[ctrlTextWidth]] but does not require a control and can be used to estimate text width for any control including buttons. Result does not include left and right margins (hardcoded at 0.008 each).
____________________________________________________________________________________________
{{Feature|informative|This command always uses unicode (see also [[forceUnicode]]).}}


| Returns estimated width of the text based on font type and size. Similar to [[ctrlTextWidth]] but doesn't require a control and can be used to estimate text width for any control including buttons. Result does not include left and right margins (hardcoded at 0.008 each).  |DESCRIPTION=
|s1= text [[getTextWidth]] [font, size]
____________________________________________________________________________________________


| text [[getTextWidth]] [font, size] |SYNTAX=
|p1= text: [[String]] - text string to measure


|p1= text: [[String]] - text string to measure |PARAMETER1=
|p2= font: [[String]] - [[FXY_File_Format#Available_Fonts|font type]]
|p2= [font, size]: [[Array]]  |PARAMETER2=
|p3= font: [[String]] - font type |PARAMETER3=
|p4= size: [[Number]] - font size |PARAMETER4=


| [[Number]] |RETURNVALUE=
|p3= size: [[Number]] - font size


|r1= [[Number]]


|x1= <code>_textWidth = "Hello World" [[getTextWidth]] ["PuristaMedium", 0.03];</code>|EXAMPLE1=
|x1= <sqf>_textWidth = "Hello World" getTextWidth ["PuristaMedium", 0.03];</sqf>
|x2= <code>_textWidthInclMargins = ("Hello World" [[getTextWidth]] ["PuristaMedium", 0.03]) + 0.016;</code>|EXAMPLE2=
|x3= <code>[[private]] _ctrl = [[findDisplay]] 46 [[ctrlCreate]] ["RscText", -1];
_ctrl [[ctrlSetText]] "TestString";
_ctrl [[ctrlSetFont]] "PuristaMedium";
_ctrl [[ctrlSetFontHeight]] 0.04;
[[ctrlTextWidth]] _ctrl == ("TestString" [[getTextWidth]] ["PuristaMedium", 0.04]) + 0.016; {{cc | true}}</code>|EXAMPLE3=


____________________________________________________________________________________________
|x2= <sqf>_textWidthInclMargins = ("Hello World" getTextWidth ["PuristaMedium", 0.03]) + 0.016;</sqf>


| [[ctrlTextWidth]] |SEEALSO=
|x3= <sqf>
#define MARGINS 0.0016
private _ctrl = findDisplay 46 ctrlCreate ["RscText", -1];
_ctrl ctrlSetText "TestString";
_ctrl ctrlSetFont "PuristaMedium";
_ctrl ctrlSetFontHeight 0.04;
ctrlTextWidth _ctrl == ("TestString" getTextWidth ["PuristaMedium", 0.04]) + MARGINS; // true
</sqf>


| |MPBEHAVIOUR=  
|seealso= [[ctrlTextWidth]]
____________________________________________________________________________________________
}}
}}


<h3 style='display:none'>Notes</h3>
{{Note
<dl class='command_description'>
|user= R3vo
<!-- Note Section BEGIN -->
|timestamp= 20201028221000
|text= When working with multiline controls [[ctrlTextWidth]] or [[getTextWidth]] will not return a proper value since the text will be treated as one long line.<br>
'''Solution (Execute in [[:Category:Eden Editor|Eden Editor]]):'''
<sqf>
disableSerialization;


<!-- Note Section END -->
private _display = findDisplay 313 createDisplay "RscDisplayEmpty";
</dl>


<h3 style='display:none'>Bottom Section</h3>
private _edit = _display ctrlCreate ["RscEditMulti", -1];
[[Category:Scripting Commands|{{uc:{{PAGENAME}}}}]]
_edit ctrlSetPosition [0,0,1,1];
[[Category:Arma 3: New Scripting Commands List|{{uc:{{PAGENAME}}}}]]
_edit ctrlSetBackgroundColor [0,0,0,1];
[[Category:Scripting Commands Arma 3|{{uc:{{PAGENAME}}}}]]
_edit ctrlSetFont "EtelkaMonospacePro";
_edit ctrlSetFontHeight 0.03;
_edit ctrlCommit 0;


<!-- CONTINUE Notes -->
private _longestLineWidth = 0;
private _exampleString = "abcdefghijklmnopqrstuvxyz0134567890";
private _text = "";


<!-- DISCONTINUE Notes -->
for "_lines" from 1 to 400 do // loop through all lines and find the longest one
{
_lineText = _exampleString select [round random 35];
_longestLineWidth = _longestLineWidth max (_lineText getTextWidth ["EtelkaMonospacePro", 0.03]);
_text = _text + _lineText + endl;
};
 
_edit ctrlSetPositionW (_longestLineWidth + 2 * 0.008); // width of longest line + left and right margin set in engine
_edit ctrlCommit 0;
_edit ctrlSetText _text;
</sqf>
}}

Latest revision as of 19:48, 3 September 2024

Hover & click on the images for description

Description

Description:
Returns estimated width of the text based on font type and size. Similar to ctrlTextWidth but does not require a control and can be used to estimate text width for any control including buttons. Result does not include left and right margins (hardcoded at 0.008 each).
This command always uses unicode (see also forceUnicode).
Groups:
GUI ControlStrings

Syntax

Syntax:
text getTextWidth [font, size]
Parameters:
text: String - text string to measure
font: String - font type
size: Number - font size
Return Value:
Number

Examples

Example 1:
_textWidth = "Hello World" getTextWidth ["PuristaMedium", 0.03];
Example 2:
_textWidthInclMargins = ("Hello World" getTextWidth ["PuristaMedium", 0.03]) + 0.016;
Example 3:
#define MARGINS 0.0016 private _ctrl = findDisplay 46 ctrlCreate ["RscText", -1]; _ctrl ctrlSetText "TestString"; _ctrl ctrlSetFont "PuristaMedium"; _ctrl ctrlSetFontHeight 0.04; ctrlTextWidth _ctrl == ("TestString" getTextWidth ["PuristaMedium", 0.04]) + MARGINS; // true

Additional Information

See also:
ctrlTextWidth

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
R3vo - c
Posted on Oct 28, 2020 - 22:10 (UTC)
When working with multiline controls ctrlTextWidth or getTextWidth will not return a proper value since the text will be treated as one long line.
Solution (Execute in Eden Editor):
disableSerialization; private _display = findDisplay 313 createDisplay "RscDisplayEmpty"; private _edit = _display ctrlCreate ["RscEditMulti", -1]; _edit ctrlSetPosition [0,0,1,1]; _edit ctrlSetBackgroundColor [0,0,0,1]; _edit ctrlSetFont "EtelkaMonospacePro"; _edit ctrlSetFontHeight 0.03; _edit ctrlCommit 0; private _longestLineWidth = 0; private _exampleString = "abcdefghijklmnopqrstuvxyz0134567890"; private _text = ""; for "_lines" from 1 to 400 do // loop through all lines and find the longest one { _lineText = _exampleString select [round random 35]; _longestLineWidth = _longestLineWidth max (_lineText getTextWidth ["EtelkaMonospacePro", 0.03]); _text = _text + _lineText + endl; }; _edit ctrlSetPositionW (_longestLineWidth + 2 * 0.008); // width of longest line + left and right margin set in engine _edit ctrlCommit 0; _edit ctrlSetText _text;