DialogControls-ControlsGroup: Difference between revisions

From Bohemia Interactive Community
Category: Dialogs
m (Text replacement - "{{Informative|TokenNames common to most controls, such as x, y, w, h, text, idc... are not listed here.}}" to "{{Informative|TokenNames common to most controls, such as x, y, w, h, text, idc... can be found [[Arma:_GUI_Configuration...)
m (Formatted the notes and updated the example.)
Line 156: Line 156:


==Example Config==
==Example Config==
*In this example, the child control My_RscStructuredText is higher (h value) than the parent control, so a vertical scrollbar is automatically created, which allows scrolling the entire length of the structured text display
{{Informative|*If the h value of a child control inside the controls class is larger than the h value of the controls group, a vertical scroll bar will be created. The same applies to the horizontal scroll bar.
*A generalised screw-up occurs in Arrowhead rscControlGroup where color is not specified for V and H scrollbars and shadow should not have been specified. As a result any deriving class:  
*Positioning of controls inside control groups is relative to controls group's position}}
 
{{Important|*A generalised screw-up occurs in Arrowhead rscControlGroup where color is not specified for V and H scrollbars and shadow should not have been specified. As a result any deriving class:  
**a) cannot inherit the existing scrollbar
**a) cannot inherit the existing scrollbar
**b) must repeat the entire thing with the addition of color.
**b) must repeat the entire thing with the addition of color.}}
 
 
<syntaxhighlight lang="cpp">/*
    INCLUDE INHERITED ENTRIES: false
    SHOW CLASSES ONLY: false
    CONFIG PATH: C:\Users\Robert\OneDrive\Dokumente\Arma 3 - Other Profiles\R3vo\missions\TESTING\scriptLibrary.vr\description.ext/Dialog
    SOURCE ADD-ON(S):
*/


<syntaxhighlight lang="cpp">class RscControlsGroup 
class Dialog
{
{
type = CT_CONTROLS_GROUP;
    idd = -1;
idc = -1;
    class Controls
style = ST_MULTI;
     {
        x = 0;     y = 0; w = 1; h = 1;
        class _CT_CONTROLS_GROUP
shadow=0;
        {
class VScrollbar
            type = 15;
{
            idc = -1;
width = 0.021;
            style = 16;
autoScrollSpeed = -1;
            x = 0;
autoScrollDelay = 5;
            y = 0;
autoScrollRewind = 0;
            w = 1;
                shadow=0;
            h = 1;
};
            shadow = 0;
            class ScrollBar
class HScrollbar
            {
{
height = 0.028;
                shadow=0;
};
class ScrollBar
{
                 color[] = {1,1,1,0.6};
                 color[] = {1,1,1,0.6};
colorActive[] = {1,1,1,1};
                colorActive[] = {1,1,1,1};
colorDisabled[] = {1,1,1,0.3};
                colorDisabled[] = {1,1,1,0.3};
thumb = "#(argb,8,8,3)color(1,1,1,1)";
                thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa";
arrowEmpty = "#(argb,8,8,3)color(1,1,1,1)";
                arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa";
arrowFull = "#(argb,8,8,3)color(1,1,1,1)";
                arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa";
border = "#(argb,8,8,3)color(1,1,1,1)";
                border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa";
};
            };
class Controls{};// an empty class telling the engine, no custom, additional controls
            class VScrollbar: ScrollBar
};
            {
class dialog
                width = 0.021;
{
                autoScrollSpeed = -1;
  class controls
                autoScrollDelay = 5;
  {
                autoScrollRewind = 0;
    class MyControls:RscControlsGroup
                shadow = 0;
    {
            };
x = (safeZoneX + (SafezoneW * 0.0363)); // scalability code which resizes correctly no matter what gui size or screen dimensions is used
            class HScrollbar: ScrollBar
y = (safeZoneY + (SafezoneH * 0.132));   // scalability code which resizes correctly no matter what gui size or screen dimensions is used
            {
w = (SafezoneW  * 0.31);                 // scalability code which resizes correctly no matter what gui size or screen dimensions is used
                height = 0.028;
h = (SafezoneH  * 0.752);               // scalability code which resizes correctly no matter what gui size or screen dimensions is used
                shadow = 0;
 
            };
        class Controls
            class Controls
{
            {
...class whatever additional controls you want
                class _CT_EDIT
  };
                {
    };
                    idc = -1;
  };
                    onLoad = "params ['_ctrl']; _ctrl ctrlSetText loadFile 'A3\functions_f\Actions\fn_packStaticWeapon.sqf'";
                    type = 2;
                    style = 16;
                    autocomplete = "";
                    canModify = 1;
                    colorBackground[] = {0,0,0,0.5};
                    colorText[] = {1,1,1,1};
                    colorDisabled[] = {1,1,1,0.25};
                    colorSelection[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.77])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.51])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.08])",1};
                    text = "";
                    x = 0;
                    y = 0;
                    w = 2;
                    h = 2;
                    sizeEx = 0.05;
                    font = "RobotoCondensedLight";
                };
            };
        };
    };
};</syntaxhighlight>
};</syntaxhighlight>
[[Category: Dialogs|Controls Group]]
[[Category: Dialogs|Controls Group]]

Revision as of 17:40, 20 March 2020

Template:SideTOC

CT_CONTROLS_GROUP Type=15

TokenNames common to most controls, such as x, y, w, h, text, idc... can be found here.
  • Any child controls need to be defined in the controlsGroup's subclass Controls {};
  • The x and y coords of any child controls are relative to the controlsGroups position. The height and width are not and are in screen space dimensions.
  • If the position or height/width of any child controls cause any part of the child control to fall outside the dimensions of the controlsGroup then scrollbars will be seen
    • This allows the creation of scrollable active text controls etc


Properties
Name Type Remark
ScrollBar class Default parent class for all scrollbar settings
VScrollbar class Settings relating to Vertical scrollbar
HScrollbar class Settings relating to Horizontal scrollbar
Controls class Any user added controls to be contained within the controlsGroup



class Scrollbar

Parent class used to define all available properties of VScrollbar and HScrollbar. Not all available properties make sense for each of these as outlined below.

Properties
Name Type Remark
color color array color of thumb and arrow heads, also arrow backgrounds when pressed
colorActive color array
colorDisabled color array
width/height Number width/height of the controlsGroup's scroll bars in screen space dimensions. Setting to 0 will cause no scrollbar to be shown even if a child falls outside the controlsGroup's dimensions
autoScrollEnabled Number 1 - enabled, 0 - disabled, Does not work if there a interactive controls within the controlsGroup e.g Buttons
autoScrollSpeed Number default -1, smaller numbers scroll faster, cannot be forced to scroll backwards by supplying negative numbers
autoScrollDelay Number time in seconds before autoScroll starts, restarts after user input and time before rewind happens when the end has been reached
autoScrollRewind Number 0 - disable, 1 - enabled : If autoScroll reaches the bottom of the controlsGroup it will wait autoScrollDelay then fade out, scroll back to the top, fade back in, wait autoScrollDelay before proceeding to start auto scrolling again.
thumb String path to texture or Procedural Texture "#(argb,8,8,3)color(1,1,1,1)";
arrowEmpty/Full String path to texture or Procedural Texture "#(argb,8,8,3)color(1,1,1,1)";
border String path to texture or Procedural Texture "#(argb,8,8,3)color(1,1,1,1)";
shadow Number
scrollSpeed Number default 0.06 : Speed of user vertical scroll input when using the mouse wheel, can be set to 0 to disable the user from being able to scroll, can be set to negative number to reverse scroll direction.


class VScrollbar

Properties
Name
color
colorActive
colorDisabled
width
autoScrollEnabled
autoScrollSpeed
autoScrollDelay
autoScrollRewind
thumb
arrowEmpty/Full
border
shadow
scrollSpeed


class HScrollbar

Properties
Name
color
colorActive
colorDisabled
height
thumb
arrowEmpty/Full
border
shadow


class Controls

  • Additional user added controls of any type can be added in a derived class. the base is empty because the engine looks for it regardless.

Example Config

  • If the h value of a child control inside the controls class is larger than the h value of the controls group, a vertical scroll bar will be created. The same applies to the horizontal scroll bar.
  • Positioning of controls inside control groups is relative to controls group's position
  • A generalised screw-up occurs in Arrowhead rscControlGroup where color is not specified for V and H scrollbars and shadow should not have been specified. As a result any deriving class:
    • a) cannot inherit the existing scrollbar
    • b) must repeat the entire thing with the addition of color.


/*
    INCLUDE INHERITED ENTRIES: false
    SHOW CLASSES ONLY: false
    CONFIG PATH: C:\Users\Robert\OneDrive\Dokumente\Arma 3 - Other Profiles\R3vo\missions\TESTING\scriptLibrary.vr\description.ext/Dialog
    SOURCE ADD-ON(S): 
*/

class Dialog
{
    idd = -1;
    class Controls
    {
        class _CT_CONTROLS_GROUP
        {
            type = 15;
            idc = -1;
            style = 16;
            x = 0;
            y = 0;
            w = 1;
            h = 1;
            shadow = 0;
            class ScrollBar
            {
                color[] = {1,1,1,0.6};
                colorActive[] = {1,1,1,1};
                colorDisabled[] = {1,1,1,0.3};
                thumb = "\A3\ui_f\data\gui\cfg\scrollbar\thumb_ca.paa";
                arrowEmpty = "\A3\ui_f\data\gui\cfg\scrollbar\arrowEmpty_ca.paa";
                arrowFull = "\A3\ui_f\data\gui\cfg\scrollbar\arrowFull_ca.paa";
                border = "\A3\ui_f\data\gui\cfg\scrollbar\border_ca.paa";
            };
            class VScrollbar: ScrollBar
            {
                width = 0.021;
                autoScrollSpeed = -1;
                autoScrollDelay = 5;
                autoScrollRewind = 0;
                shadow = 0;
            };
            class HScrollbar: ScrollBar
            {
                height = 0.028;
                shadow = 0;
            };
            class Controls
            {
                class _CT_EDIT
                {
                    idc = -1;
                    onLoad = "params ['_ctrl']; _ctrl ctrlSetText loadFile 'A3\functions_f\Actions\fn_packStaticWeapon.sqf'";
                    type = 2;
                    style = 16;
                    autocomplete = "";
                    canModify = 1;
                    colorBackground[] = {0,0,0,0.5};
                    colorText[] = {1,1,1,1};
                    colorDisabled[] = {1,1,1,0.25};
                    colorSelection[] = {"(profilenamespace getvariable ['GUI_BCG_RGB_R',0.77])","(profilenamespace getvariable ['GUI_BCG_RGB_G',0.51])","(profilenamespace getvariable ['GUI_BCG_RGB_B',0.08])",1};
                    text = "";
                    x = 0;
                    y = 0;
                    w = 2;
                    h = 2;
                    sizeEx = 0.05;
                    font = "RobotoCondensedLight";
                };
            };
        };
    };
};