- gtkButtonGtkButton* gtkButton; 
- getButtonStructGtkButton* getButtonStruct() 
- getStructvoid* getStruct() 
- the main Gtk struct as a void* 
- setStructvoid setStruct(GObject* obj) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- __anonymousmixin ActionableT!(GtkButton)  
- Undocumented in source. 
- __anonymousmixin ActivatableT!(GtkButton)  
- Undocumented in source. 
- setIconSizevoid setIconSize(IconSize iconSize) 
- getIconSizeIconSize getIconSize() 
- getTypeGType getType() 
- clickedvoid clicked() 
- Emits a #GtkButton::clicked signal to the given #GtkButton. 
- entervoid enter() 
- Emits a #GtkButton::enter signal to the given #GtkButton. 
- getAlignmentvoid getAlignment(float xalign, float yalign) 
- Gets the alignment of the child in the button. 
- getAlwaysShowImagebool getAlwaysShowImage() 
- Returns whether the button will ignore the #GtkSettings:gtk-button-images
setting and always show the image, if available. 
- getEventWindowWindow getEventWindow() 
- Returns the button’s event window if it is realized, %NULL otherwise.
This function should be rarely needed. 
- getFocusOnClickbool getFocusOnClick() 
- Returns whether the button grabs focus when it is clicked with the mouse.
See gtk_button_set_focus_on_click(). 
- getImageWidget getImage() 
- Gets the widget that is currenty set as the image of @button.
This may have been explicitly set by gtk_button_set_image()
or constructed by gtk_button_new_from_stock(). 
- getImagePositionGtkPositionType getImagePosition() 
- Gets the position of the image relative to the text
inside the button. 
- getLabelstring getLabel() 
- Fetches the text from the label of the button, as set by
gtk_button_set_label(). If the label text has not
been set the return value will be %NULL. This will be the
case if you create an empty button with gtk_button_new() to
use as a container. 
- getReliefGtkReliefStyle getRelief() 
- Returns the current relief style of the given #GtkButton. 
- getUseStockbool getUseStock() 
- Returns whether the button label is a stock item. 
- getUseUnderlinebool getUseUnderline() 
- Returns whether an embedded underline in the button label indicates a
mnemonic. See gtk_button_set_use_underline (). 
- leavevoid leave() 
- Emits a #GtkButton::leave signal to the given #GtkButton. 
- pressedvoid pressed() 
- Emits a #GtkButton::pressed signal to the given #GtkButton. 
- releasedvoid released() 
- Emits a #GtkButton::released signal to the given #GtkButton. 
- setAlignmentvoid setAlignment(float xalign, float yalign) 
- Sets the alignment of the child. This property has no effect unless
the child is a #GtkMisc or a #GtkAlignment. 
- setAlwaysShowImagevoid setAlwaysShowImage(bool alwaysShow) 
- If %TRUE, the button will ignore the #GtkSettings:gtk-button-images
setting and always show the image, if available. 
- setFocusOnClickvoid setFocusOnClick(bool focusOnClick) 
- Sets whether the button will grab focus when it is clicked with the mouse.
Making mouse clicks not grab focus is useful in places like toolbars where
you don’t want the keyboard focus removed from the main area of the
application. 
- setImagevoid setImage(Widget image) 
- Set the image of @button to the given widget. The image will be
displayed if the label text is %NULL or if
#GtkButton:always-show-image is %TRUE. You don’t have to call
gtk_widget_show() on @image yourself. 
- setImagePositionvoid setImagePosition(GtkPositionType position) 
- Sets the position of the image relative to the text
inside the button. 
- setLabelvoid setLabel(string label) 
- Sets the text of the label of the button to @str. This text is
also used to select the stock item if gtk_button_set_use_stock()
is used. 
- setReliefvoid setRelief(GtkReliefStyle relief) 
- Sets the relief style of the edges of the given #GtkButton widget.
Two styles exist, %GTK_RELIEF_NORMAL and %GTK_RELIEF_NONE.
The default style is, as one can guess, %GTK_RELIEF_NORMAL.
The deprecated value %GTK_RELIEF_HALF behaves the same as
%GTK_RELIEF_NORMAL. 
- setUseStockvoid setUseStock(bool useStock) 
- If %TRUE, the label set on the button is used as a
stock id to select the stock item for the button. 
- setUseUnderlinevoid setUseUnderline(bool useUnderline) 
- If true, an underline in the text of the button label indicates
the next character should be used for the mnemonic accelerator key. 
- OnActivateDelegateWrapperclass OnActivateDelegateWrapper 
- Undocumented in source. 
- onActivateListenersOnActivateDelegateWrapper[] onActivateListeners; 
- Undocumented in source. 
- addOnActivategulong addOnActivate(void delegate(Button) dlg, ConnectFlags connectFlags) 
- The ::activate signal on GtkButton is an action signal and
emitting it causes the button to animate press then release.
Applications should never connect to this signal, but use the
#GtkButton::clicked signal. 
- callBackActivatevoid callBackActivate(GtkButton* buttonStruct, OnActivateDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackActivateDestroyvoid callBackActivateDestroy(OnActivateDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnActivatevoid internalRemoveOnActivate(OnActivateDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- OnClickedDelegateWrapperclass OnClickedDelegateWrapper 
- Undocumented in source. 
- onClickedListenersOnClickedDelegateWrapper[] onClickedListeners; 
- Undocumented in source. 
- addOnClickedgulong addOnClicked(void delegate(Button) dlg, ConnectFlags connectFlags) 
- Emitted when the button has been activated (pressed and released). 
- callBackClickedvoid callBackClicked(GtkButton* buttonStruct, OnClickedDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackClickedDestroyvoid callBackClickedDestroy(OnClickedDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnClickedvoid internalRemoveOnClicked(OnClickedDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- OnEnterDelegateWrapperclass OnEnterDelegateWrapper 
- Undocumented in source. 
- onEnterListenersOnEnterDelegateWrapper[] onEnterListeners; 
- Undocumented in source. 
- addOnEntergulong addOnEnter(void delegate(Button) dlg, ConnectFlags connectFlags) 
- Emitted when the pointer enters the button. 
- callBackEntervoid callBackEnter(GtkButton* buttonStruct, OnEnterDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackEnterDestroyvoid callBackEnterDestroy(OnEnterDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnEntervoid internalRemoveOnEnter(OnEnterDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- OnLeaveDelegateWrapperclass OnLeaveDelegateWrapper 
- Undocumented in source. 
- onLeaveListenersOnLeaveDelegateWrapper[] onLeaveListeners; 
- Undocumented in source. 
- addOnLeavegulong addOnLeave(void delegate(Button) dlg, ConnectFlags connectFlags) 
- Emitted when the pointer leaves the button. 
- callBackLeavevoid callBackLeave(GtkButton* buttonStruct, OnLeaveDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackLeaveDestroyvoid callBackLeaveDestroy(OnLeaveDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnLeavevoid internalRemoveOnLeave(OnLeaveDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- OnPressedDelegateWrapperclass OnPressedDelegateWrapper 
- Undocumented in source. 
- onPressedListenersOnPressedDelegateWrapper[] onPressedListeners; 
- Undocumented in source. 
- addOnPressedgulong addOnPressed(void delegate(Button) dlg, ConnectFlags connectFlags) 
- Emitted when the button is pressed. 
- callBackPressedvoid callBackPressed(GtkButton* buttonStruct, OnPressedDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackPressedDestroyvoid callBackPressedDestroy(OnPressedDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnPressedvoid internalRemoveOnPressed(OnPressedDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- OnReleasedDelegateWrapperclass OnReleasedDelegateWrapper 
- Undocumented in source. 
- onReleasedListenersOnReleasedDelegateWrapper[] onReleasedListeners; 
- Undocumented in source. 
- addOnReleasedgulong addOnReleased(void delegate(Button) dlg, ConnectFlags connectFlags) 
- Emitted when the button is released. 
- callBackReleasedvoid callBackReleased(GtkButton* buttonStruct, OnReleasedDelegateWrapper wrapper) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- callBackReleasedDestroyvoid callBackReleasedDestroy(OnReleasedDelegateWrapper wrapper, GClosure* closure) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
- internalRemoveOnReleasedvoid internalRemoveOnReleased(OnReleasedDelegateWrapper source) 
- Undocumented in source. Be warned that the author may not have intended to support it. 
GtkModelButton is a button class that can use a #GAction as its model. In contrast to #GtkToggleButton or #GtkRadioButton, which can also be backed by a #GAction via the #GtkActionable:action-name property, GtkModelButton will adapt its appearance according to the kind of action it is backed by, and appear either as a plain, check or radio button.
Model buttons are used when popovers from a menu model with gtk_popover_new_from_model(); they can also be used manually in a #GtkPopoverMenu.
When the action is specified via the #GtkActionable:action-name and #GtkActionable:action-target properties, the role of the button (i.e. whether it is a plain, check or radio button) is determined by the type of the action and doesn't have to be explicitly specified with the #GtkModelButton:role property.
The content of the button is specified by the #GtkModelButton:text and #GtkModelButton:icon properties.
The appearance of model buttons can be influenced with the #GtkModelButton:centered and #GtkModelButton:iconic properties.
Model buttons have built-in support for submenus in #GtkPopoverMenu. To make a GtkModelButton that opens a submenu when activated, set the #GtkModelButton:menu-name property. To make a button that goes back to the parent menu, you should set the #GtkModelButton:inverted property to place the submenu indicator at the opposite side.
Example
|[ <object class="GtkPopoverMenu"> <child> <object class="GtkBox"> <property name="visible">True</property> <property name="margin">10</property> <child> <object class="GtkModelButton"> <property name="visible">True</property> <property name="action-name">view.cut</property> <property name="text" translatable="yes">Cut</property> </object> </child> <child> <object class="GtkModelButton"> <property name="visible">True</property> <property name="action-name">view.copy</property> <property name="text" translatable="yes">Copy</property> </object> </child> <child> <object class="GtkModelButton"> <property name="visible">True</property> <property name="action-name">view.paste</property> <property name="text" translatable="yes">Paste</property> </object> </child> </object> </child> </object> ]|
CSS nodes
|[<!-- language="plain" --> modelbutton ├── <child> ╰── check ]|
|[<!-- language="plain" --> modelbutton ├── <child> ╰── radio ]|
|[<!-- language="plain" --> modelbutton ├── <child> ╰── arrow ]|
GtkModelButton has a main CSS node with name modelbutton, and a subnode, which will have the name check, radio or arrow, depending on the role of the button and whether it has a menu name set.
The subnode is positioned before or after the content nodes and gets the .left or .right style class, depending on where it is located.
|[<!-- language="plain" --> button.model ├── <child> ╰── check ]|
Iconic model buttons (see #GtkModelButton:iconic) change the name of their main node to button and add a .model style class to it. The indicator subnode is invisible in this case.