uicontrol properties
Description of the uicontrol properties.
Description
These properties can be set using the set or uicontrol functions and their value can be obtained with the get.
Properties
- BackgroundColor
- [1,3] real vector or string - Background color of the uicontrol. A color is specified as Red, Green and Blue values. Those values are real in [0,1]. The color can be given as a real vector, ie [R,G,B] or a string where each value is separated by a "|", ie "R|G|B". - Setting this property to - [-1 -1 -1]will let the look and feel set the default background color.
- Border
- A Border object. - Only used for - framestyle uicontrols, this object is created using createBorder.- Setting this value to - []removes the border of the frame.
- Callback
- String - Instruction evaluated by the Scilab interpreter when an uicontrol is activated (for example when you click on a button). - This property is not used for - layer,- frameand- textstyle uicontrols.
- Callback_Type
- Scalar - The type of callback transmitted to the uicontrol (see example below). - -1
- none (callback deactivated) 
- 0(by default)
- non prioritary (or interruptible) Scilab instructions 
- 1
- Cor a Fortran function 
- 2
- non prioritary (or interruptible) Scilab function 
- 10
- prioritary (or non-interruptible) Scilab instructions 
- 12
- prioritary (or non-interruptible) Scilab function 
 
- Constraints
- A Constraints object. - This object is created using createConstraints and describes the constraints on the position and size of the uicontrol regarding to its parent. - Setting this value to - []clears the constraints.
- Enable
- {on} | off - Enable or disable the uicontrol. If this property is set to - "on"(default), the uicontrol is operational, but if this property is set to- "off", the uicontrol will not respond to the mouse actions and will be grayed out.
- FontAngle
- {normal} | italic | oblique - For a control containing some text, this property sets the slant of the font. 
- FontSize
- Scalar - For a control containing some text, this property sets the size of the font in FontUnits. 
- FontUnits
- {points} | pixels | normalized - For a control containing some text, this property sets the units with which the FontSize is specified. 
- FontWeight
- light | {normal} | demi | bold - For a control containing some text, this property sets the weight of the used font. 
- FontName
- String - Used to choose the name of the font selected to display the text of the control. 
- ForegroundColor
- [1,3] real vector or string - Foreground color of the uicontrol. A color is specified as Red, Green and Blue values. Those values are real in [0,1]. The color can be given as a real vector, ie [R,G,B] or a string where each value is separated by a "|", ie "R|G|B". - Setting this property to - [-1 -1 -1]will let the look and feel set the default foreground color.
- Groupname
- String - Used for - radiobuttonand- checkboxstyle uicontrols, this property allow to manage uicontrols of the same group as a whole. For example,- checkboxuicontrols of a group will manage selection unicity automatically.
- HorizontalAlignment
- left | {center} | right - Set text horizontal alignment in the uicontrol. 
- Icon
- String. - This property represents the relative (to Scilab working directory) or absolute path of the image file to be used as icon for a - pushbuttonor- textuicontrol.- For - frameuicontrols in- tabuicontrols, the icon property sets the icon of its sheet.
- Layout:
- This property sets the layout used to dispose - frameuicontrols children. See layout page for more information about available layouts.
- Layout_options:
- This property sets the options of the layout used to dispose - framechildren. See layout page for more information about available options.
- ListboxTop
- Scalar - Only used for - listboxuicontrols, this property tells which item of the list appears on the first line of the visible area of the list.
- Margins
- [1,4] real vector. - Sets an empty space around the uicontrol under the form - [top, left, bottom, right](in pixels).
- Max
- Scalar - Specifies the largest value the "Value" property can be set to. It has however different meaning on each uicontrol: - checkboxand- radiobuttonuicontrols: Max is the value the "Value" property take when control is checked.
- sliderand- spinneruicontrols: Maximum value of the component.
- listboxuicontrols: if (Max-Min)>1 the list allows multiple selection.
- edituicontrols: if (Max-Min)>1 the edit allows multiple line edition.
 
- Min
- Scalar - Specifies the lowest value the "Value" property can be set to. It has however different meaning on each uicontrol: - checkboxand- radiobuttonuicontrols: Min is the value the "Value" property take when control is unchecked.
- sliderand- spinneruicontrols: Minimum value of the component.
- listboxuicontrols: if (Max-Min)>1 the list allows multiple selection.
- edituicontrols: if (Max-Min)>1 the edit allows multiple line edition.
 
- Parent
- Handle - Handle of the uicontrol parent. Changing this property allows to move a control from a figure to another. 
- Position
- [x y w h] numerical vector (as stored) or a "x|y|w|h" string. - Sets or gets the position and size of the component, the referential being - .parent.axes_size, if .parent is a Figure
- .parent.position, if .parent is a uicontrol Frame.
 - The value is a vector [x y w h] where - x is the horizontal position of the left side of the component with respect to the left edge of the referential.
- y is the vertical position of the bottom side of the component with respect to the bottom edge of the referential.
- w and h are the width and height of the uicontrol component.
 - The unit is set by the .Units property. - For sliders: w > h sets the slider horizontally, and vertically otherwise. 
- Relief
- {default} | flat | groove | raised | ridge | solid | sunken - Appearance of the border of the uicontrol. - "default"means that the application look and feel will be used to set the relief.- When using the deprecated skin for uicontrols, default values are related to uicontrol style: - pushbuttonuicontrols: the default value for "Relief" property is "raised".
- edituicontrols: the default value for "Relief" property is "sunken".
- Other uicontrols: the default value for "Relief" property is relief by default provided by java language. 
 
- Scrollable
- Boolean. - Used for - frameand- editstyle uicontrols, this property indicates if the uicontrol must have scrolling capabilities (- %T) or not (default- %F).- For - framethis value must be set at creation.
- SliderStep
- [1,2] real vector - [small big], the small step represents the movement achieved when clicking on the slider trough or tapping on the keyboard arrows (when the slider has focus); the big step is the amount moved when using Ctrl-keyboard-arrows. If the big step is omitted, it is defaulted to 1/10 of the scale. - For - spinneruicontrol, the first value of this property is used as fixed step.
- SnapToTicks
- on | {off} - If - SnapToTicksis- "on", the Slider knob will always snap to the closest position associated to a value given by the "Min" property plus an integer multiple of small step (see SliderStep above). The default value of this property is "off".
- String
- String. - This property represents the text appearing in a uicontrol (Except for Frame, Slider, and Spinner styles). For tables, the value is a string matrix. For ListBoxes and PopupMenus, the value can be a vector of string or a string where the items are separated by a "|". For Text uicontrols, this string can contain HTML code to format the text. - For - pushbuttonor- textuicontrols, if the text is enclosed between two $ (dollar sign), then it will be considered as a LaTeX expression, and if it is enclosed between < and >, it will be considered as a MathML one.
- For - layerand- tabuicontrols, the value specifies the tag of the selected child.
- For - imageuicontrols, the value specifies the path of the image file.
- For - tableuicontrols, the value specifies the ole table data:- [IGNORED COL1-HEADER...COLN-HEADER;ROW1-HEADER, ROW1COL1-DATA, ROW1COLN-DATA;...;ROWM-HEADER, ROWMCOL1-DATA, ROWMCOLN-DATA].
- For - listboxand- popupmenuuicontrols which manage colors selection, icons, background and foreground colors, the- Stringproperty can be set to a matrix matching the format:- ["#color1", "Item1", "#background1", "#foreground1"; "#color2", "Item2", ..., ...]- ["icon1", "Item1", "#background1", "#foreground1"; "icon2", "Item2", ..., ...]with- "#color1",- "#background1"and- "#foreground1"in HTML format- #XXXXXX. Then the component will display a colored box or icon on the left of the associated string, and different background/foreground colors for items.
 
- Tag
- String - This property is generally used to identify the control. It allows to give it a "name". Mainly used in conjunction with - findobj().
- Title_position
- {top} | left | bottom | right - The position of the tabs of a - tabstyle uicontrol.
- Title_scroll
- Boolean - Indicates whether the tabs of a - tabstyle uicontrol must be wrapped (- title_scroll=%F) or scrolled (- title_scroll=%T).
- TooltipString
- String or String vector - This property represents the text of the uicontrol tooltip appearing when the mouse is over the uicontrol. 
- Units
- {points} | pixels | normalized - Set the units used to specify the "Position" property. Normalized positions and sizes are in [0, 1]: - If .parent is a "figure", they are within and refer to the .parent.axes_size area.
- If .parent is an uicontrol of style "frame", they are within and refer to the .parent.position area.
 
- Userdata
- Scilab data - This can be used to associate some Scilab objects (string,string matrix, matrix mxn) to an uicontrol. 
- Value
- Scalar or vector - Value of the uicontrol. The exact meaning depends on the style of the uicontrol: - checkboxand- radiobuttonuicontrols: value is set to Max (see above) when on and Min when off.
- listboxand- popupmenuuicontrols: value is a vector of indexes corresponding to the indexes of the selected entries in the list. 1 is the first item of the list.
- sliderand- spinneruicontrols: numerical value indicated by the component.
- layerand- tabuicontrols: index of displayed component.
- imageuicontrols: value is used to set some image properties- [X-Scale Y-Scale X-Shear Y-Shear RotationAngle]
 
- Verticalalignment
- top | {middle} | bottom - Set text vertical alignment in the uicontrol. This property has only effect with Text and CheckBoxes styles. 
- Visible
- {on} | off - Set the visibility of the uicontrol. If this property is set to - "on"(default), the uicontrol is visible, but if this property is set to- "off", the uicontrol will not appear in its parent figure.
Example for callback_type property
function counter_start() // Callback called after a click on start pushbutton global Stop Stop=%f; while %t i = evstr(get("count", "string")); set("count", "string", string(i+1)); if Stop then break end end endfunction function counter_stop() // Callback called after a click on stop pushbutton global Stop Stop=%t endfunction function counter_reinit() // Callback called after a click on reset pushbutton Stop=%t set("count", "string", "0"); endfunction counter_main_fig = figure( ... "dockable", "off", ... "infobar_visible", "off", ... "toolbar_visible", "off", ... "toolbar", "none", ... "menubar_visible", "off", ... "menubar", "none", ... "layout", "none", ... "visible", "off", ... "resize", "off", ... "figure_position", [0 0], ... "axes_size", [400, 150], ... "figure_name", "Counter", ... "layout", "gridbag", ... "tag", "counter_main_figure"); // Counter frame counter_frame = uicontrol(counter_main_fig, ... "layout", "gridbag", ... "style", "frame", ... "constraints", createConstraints("gridbag", [1, 1, 1, 1], [1, 0.5], "both")); uicontrol(counter_frame, ... "style", "text", ... "string", "Counter : ", ... "constraints", createConstraints("gridbag", [1, 1, 1, 1], [0.5, 1], "horizontal", "center"), ... "margins", [5 5 5 5], ... "horizontalAlignment", "center"); uicontrol(counter_frame, ... "style", "text", ... "string", "0", ... "constraints", createConstraints("gridbag", [2, 1, 1, 1], [1, 1], "horizontal", "center"), ... "tag", "count", ... "margins", [5 5 5 5]); // Buttons frame buttons_frame = uicontrol(counter_main_fig, ... "layout", "gridbag", ... "style", "frame", ... "constraints", createConstraints("gridbag", [1, 2, 1, 1], [1, 1], "both")); // The associated callback needs to be interruptible (when clicking on stop or reset for example) uicontrol("parent", buttons_frame, ... "Style" , "pushbutton", ... "String" , "Start", ... "callback" , "counter_start()", ... "margins", [5 5 5 5], ... "constraints", createConstraints("gridbag", [1, 1, 1, 1], [1, 1], "horizontal", "center")); // The associated callback needs to have priority in order to interrupt the current callback (in other words to stop the counter) uicontrol("parent", buttons_frame, ... "Style" , "pushbutton", ... "String" , "Stop", ... "callback" , "counter_stop()", ... "callback_type", 10, ... "constraints", createConstraints("gridbag", [2, 1, 1, 1], [1, 1], "horizontal", "center"), ... "margins", [5 5 5 5]); // The same for the callback which reset the counter: it must have the priority over the callback which has started the counter uicontrol("parent", buttons_frame, ... "Style" , "pushbutton", ... "String" , "Reset", ... "callback" , "counter_reinit()", ... "callback_type", 10, ... "constraints", createConstraints("gridbag", [3, 1, 1, 1], [1, 1], "horizontal", "center"), ... "margins", [5 5 5 5]); counter_main_fig.visible = "on";
See also
- uicontrol — create a Graphic User Interface object
- hidden handles / properties — Description of console object properties.
- set — set properties of some graphic objects or uimenus or uicontrol interactive components
- get — Gets the handle of a graphical or User Interface object, or the property's value of objects.
History
| Version | Description | 
| 5.5.0 | 
 | 
| 6.0.0 | By default, .callback_typeis now interruptible but non prioritary. | 
| Report an issue | ||
| << uicontrol | GUI | uigetdir >> |