togglebutton - step-/gtkdialog GitHub Wiki
A GtkToggleButton containing either a GtkLabel, a GtkImage or both packed inside a GtkHBox or GtkVBox
<togglebutton tag_attr="value"...>
<label>text</label>
<default>state</default>
<variable>varname</variable>
<height>value</height>
<width>value</width>
<input>command</input>
<input file>filename</input>
<input file icon="image"></input>
<input file stock="gtk-image"></input>
<sensitive>state</sensitive>
<action>activity</action>...
<action signal="type">activity</action>...
<action function="type">parameter</action>...
</togglebutton>
"..." denotes acceptance of multiples of the same thing.
See the GtkToggleButton widget and ancestor class properties.
The following custom tag attributes are available:
Name | Description | Value | Since |
---|---|---|---|
space-expand | Pack widget expanding into space |
true or false
|
|
space-fill | Pack widget filling space |
true or false
|
|
block-function-signals | Block signal emissions from functions |
true or false
|
|
file-monitor | Emit signal when input file(s) change |
true or false
|
0.8.1 |
auto-refresh | Auto refresh when input file(s) change |
true or false
|
0.8.1 |
image-position[1] | Image position relative to label |
0 , 1 , 2 , 3 (left, right, top, bottom) |
|
homogeneous[2] | Horizontal uniformity of an image with label |
true or false
|
0.8.1 |
theme-icon-size | The size of the GTK theme icon | An integer > 0 or -1 to ignore |
0.8.1 |
stock-icon-size | The size of the GTK stock icon |
0 to 6 (see GtkIconSize) |
0.8.1 |
Some of these may have tag attribute equivalents.
Name | Description | Contents | Since |
---|---|---|---|
label | Initial text | ||
default | Initial state |
true or false
|
|
variable | Variable name | ||
variable export="false" | Variable name, not exported to shell | 0.8.3 | |
height | Image scaling dimension | An integer > 0 or -1 to ignore |
|
width | Image scaling dimension | An integer > 0 or -1 to ignore |
|
input | Data input source | Shell command | |
input file | Data input source | Image filename | |
input file icon="image"[3] | GTK theme icon name | ||
input file stock="gtk-image"[4] | GTK stock icon ID |
gtk-about , gtk-add , ... (full list) |
|
sensitive | Sensitive state |
true or false
|
|
action | Execute command on default signal | Shell command[5] | |
action | Perform function on default signal | function:parameter[5] | |
action signal="type" | Execute command on signal | Shell command[5] | |
action signal="type" | Perform function on signal | function:parameter[5] | |
action function="type" | Perform function on default signal | parameter[5] | 0.8.3 |
action condition="type" | Execute command on default signal conditionally | Shell command[5] | 0.8.3 |
action condition="type" | Perform function on default signal conditionally | function:parameter[5] | 0.8.3 |
action signal="type" condition="type" | Execute command on signal conditionally | Shell command[5] | 0.8.3 |
action signal="type" condition="type" | Perform function on signal conditionally | function:parameter[5] | 0.8.3 |
action function="type" condition="type" | Perform function on default signal conditionally | parameter[5] | 0.8.3 |
The default signal is "toggled", emitted when the state is changed.
The "file-changed" signal is emitted if file-monitor is true and the input file being monitored has changed.
The following signals are connected-up for all widgets:
button-press-event, button-release-event, configure-event, enter-notify-event, leave-notify-event, focus-in-event, focus-out-event, hide, show, realize, key-press-event, key-release-event, map-event, unmap-event
The following functions can be performed upon this widget by any widget capable of emitting signals:
Type | Description | Parameter | Since |
---|---|---|---|
enable | Sensitise widget | Variable name | |
disable | Desensitise widget | Variable name | |
show | Show widget | Variable name | 0.8.1 |
hide | Hide widget | Variable name | 0.8.1 |
activate | Activate widget | Variable name | 0.8.1 |
grabfocus | Grab input focus | Variable name | 0.8.1 |
refresh | Reload input data | Variable name |
The following general functions can be performed by any widget capable of emitting signals:
Type | Description | Parameter | Since |
---|---|---|---|
break | Break out of actions list | None | 0.8.3 |
command | Execute command | Shell command | |
exit | Exit dialog | A value for the EXIT variable |
|
closewindow | Close dialog | Variable name | |
launch | Launch dialog | Variable name | |
presentwindow | Present dialog | Variable name | 0.8.1 |
The following conditions can be used within the condition attribute of action directives:
Type | Description | Argument | Since |
---|---|---|---|
active_is_true(argument) | Active state of toggle widget | Variable name | 0.8.3 |
active_is_false(argument) | Active state of toggle widget | Variable name | 0.8.3 |
command_is_true(argument) | Output of shell command | Shell command | 0.8.3 |
command_is_false(argument) | Output of shell command | Shell command | 0.8.3 |
file_is_true(argument) | Contents of a file | Filename | 0.8.3 |
file_is_false(argument) | Contents of a file | Filename | 0.8.3 |
sensitive_is_true(argument) | Sensitive state of widget | Variable name | 0.8.3 |
sensitive_is_false(argument) | Sensitive state of widget | Variable name | 0.8.3 |
visible_is_true(argument) | Visible state of widget | Variable name | 0.8.3 |
visible_is_false(argument) | Visible state of widget | Variable name | 0.8.3 |
true means "true", "yes" or a non-zero value, false means "false", "no" or zero, therefore the shell command is expected to echo one of these values to stdout.
-
The existing "image-position" GTK+ property -- normally only applicable to stock buttons -- has been extended to apply to all Gtkdialog buttons.
-
The existing "homogeneous" GTK+ property -- applicable to the hbox and vbox -- can be used here to effect the box inside the button when including an image and a label.
-
Theme icons default to 20 and do not scale or refresh (the "theme-icon-size" custom tag attribute can be used to request a size).
-
Stock icons default to GTK_ICON_SIZE_BUTTON and do not scale or refresh (the "stock-icon-size" custom tag attribute can be used to request a size).
-
This widget's actions can be conditionally executed (based upon its active state) by prepending its contents with
if true
orif false
although 0.8.3 introduced a dedicated condition attribute which may be more suitable.
This widget was introduced in version 0.7.21.