Gtk2HsContentsIndex
Graphics.UI.Gtk.Buttons.Button
Portabilityportable (depends on GHC)
Stabilityprovisional
Maintainergtk2hs-users@lists.sourceforge.net
Contents
Detail
Class Hierarchy
Types
Constructors
Methods
Attributes
Signals
Description
A widget that creates a signal when clicked on
Synopsis
data Button
class BinClass o => ButtonClass o
castToButton :: GObjectClass obj => obj -> Button
buttonNew :: IO Button
buttonNewWithLabel :: String -> IO Button
buttonNewWithMnemonic :: String -> IO Button
buttonNewFromStock :: String -> IO Button
buttonPressed :: ButtonClass self => self -> IO ()
buttonReleased :: ButtonClass self => self -> IO ()
buttonClicked :: ButtonClass self => self -> IO ()
buttonEnter :: ButtonClass self => self -> IO ()
buttonLeave :: ButtonClass self => self -> IO ()
data ReliefStyle
= ReliefNormal
| ReliefHalf
| ReliefNone
buttonSetRelief :: ButtonClass self => self -> ReliefStyle -> IO ()
buttonGetRelief :: ButtonClass self => self -> IO ReliefStyle
buttonSetLabel :: ButtonClass self => self -> String -> IO ()
buttonGetLabel :: ButtonClass self => self -> IO String
buttonSetUseStock :: ButtonClass self => self -> Bool -> IO ()
buttonGetUseStock :: ButtonClass self => self -> IO Bool
buttonSetUseUnderline :: ButtonClass self => self -> Bool -> IO ()
buttonGetUseUnderline :: ButtonClass self => self -> IO Bool
buttonSetFocusOnClick :: ButtonClass self => self -> Bool -> IO ()
buttonGetFocusOnClick :: ButtonClass self => self -> IO Bool
buttonSetAlignment :: ButtonClass self => self -> (Float, Float) -> IO ()
buttonGetAlignment :: ButtonClass self => self -> IO (Float, Float)
buttonGetImage :: ButtonClass self => self -> IO (Maybe Widget)
buttonSetImage :: (ButtonClass self, WidgetClass image) => self -> image -> IO ()
buttonLabel :: ButtonClass self => Attr self String
buttonUseUnderline :: ButtonClass self => Attr self Bool
buttonUseStock :: ButtonClass self => Attr self Bool
buttonFocusOnClick :: ButtonClass self => Attr self Bool
buttonRelief :: ButtonClass self => Attr self ReliefStyle
buttonXalign :: ButtonClass self => Attr self Float
buttonYalign :: ButtonClass self => Attr self Float
buttonImage :: (ButtonClass self, WidgetClass image) => ReadWriteAttr self (Maybe Widget) image
onButtonActivate :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterButtonActivate :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onClicked :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterClicked :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onEnter :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterEnter :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onLeave :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterLeave :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onPressed :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterPressed :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onReleased :: ButtonClass b => b -> IO () -> IO (ConnectId b)
afterReleased :: ButtonClass b => b -> IO () -> IO (ConnectId b)
Detail

The Button widget is generally used to attach a function to that is called when the button is pressed. The various signals and how to use them are outlined below.

The Button widget can hold any valid child widget. That is it can hold most any other standard Widget. The most commonly used child is the Label.

Class Hierarchy
 |  GObject
 |   +----Object
 |         +----Widget
 |               +----Container
 |                     +----Bin
 |                           +----Button
 |                                 +----ToggleButton
 |                                 +----ColorButton
 |                                 +----FontButton
 |                                 +----OptionMenu
 
Types
data Button
show/hide Instances
class BinClass o => ButtonClass o
show/hide Instances
castToButton :: GObjectClass obj => obj -> Button
Constructors
buttonNew :: IO Button
Creates a new Button widget. To add a child widget to the button, use containerAdd.
buttonNewWithLabel
:: Stringlabel - The text you want the Label to hold.
-> IO Button
Creates a Button widget with a Label child containing the given text.
buttonNewWithMnemonic
:: Stringlabel - The text of the button, with an underscore in front of the mnemonic character
-> IO Button
Creates a new Button containing a label. If characters in label are preceded by an underscore, they are underlined. If you need a literal underscore character in a label, use '__' (two underscores). The first underlined character represents a keyboard accelerator called a mnemonic. Pressing Alt and that key activates the button.
buttonNewFromStock
:: StringstockId - the name of the stock item
-> IO Button

Creates a new Button containing the image and text from a stock item.

If stockId is unknown, then it will be treated as a mnemonic label (as for buttonNewWithMnemonic).

Methods
buttonPressed :: ButtonClass self => self -> IO ()
Emits the button pressed signal for the given Button.
buttonReleased :: ButtonClass self => self -> IO ()
Emits the button released signal for the given Button.
buttonClicked :: ButtonClass self => self -> IO ()

Emits the button clicked signal for the given Button.

This is similar to calling buttonPressed and buttonReleased in sequence.

buttonEnter :: ButtonClass self => self -> IO ()
Emit the cursor enters signal to the button.
buttonLeave :: ButtonClass self => self -> IO ()
Emit the cursor leaves signal to the button.
data ReliefStyle
I don't have a clue.
Constructors
ReliefNormal
ReliefHalf
ReliefNone
show/hide Instances
buttonSetRelief
:: ButtonClass self
=> self
-> ReliefStylenewstyle - The ReliefStyle as described above.
-> IO ()
Sets the relief style of the edges of the given Button widget. Three styles exist, ReliefNormal, ReliefHalf, ReliefNone. The default style is, as one can guess, ReliefNormal.
buttonGetRelief
:: ButtonClass self
=> self
-> IO ReliefStylereturns The current ReliefStyle
Returns the current relief style of the given Button.
buttonSetLabel :: ButtonClass self => self -> String -> IO ()

Sets the text of the label of the button. This text is also used to select the stock item if buttonSetUseStock is used.

This will also clear any previously set labels.

buttonGetLabel :: ButtonClass self => self -> IO String
Gets the text from the label of the button, as set by buttonSetLabel. If the label text has not been set the return value will be "". This will be the case if you create an empty button with buttonNew to use as a container.
buttonSetUseStock
:: ButtonClass self
=> self
-> BooluseStock - True if the button should use a stock item
-> IO ()

If true, the label set on the button is used as a stock id to select the stock item for the button.

Setting this property to True will make the button lookup its label in the table of stock items. If there is a match, the button will use the stock item instead of the label. You need to set this flag before you change the label.

buttonGetUseStock
:: ButtonClass self
=> self
-> IO Boolreturns True if the button label is used to select a stock item instead of being used directly as the label text.
Returns whether the button label is a stock item.
buttonSetUseUnderline
:: ButtonClass self
=> self
-> BooluseUnderline - True if underlines in the text indicate mnemonics
-> IO ()

If true, an underline in the text of the button label indicates the next character should be used for the mnemonic accelerator key.

Setting this property will make the button join any underline character into the following letter and inserting this letter as a keyboard shortcut. You need to set this flag before you change the label.

buttonGetUseUnderline
:: ButtonClass self
=> self
-> IO Boolreturns True if an embedded underline in the button label indicates the mnemonic accelerator keys.
Returns whether an embedded underline in the button label indicates a mnemonic. See buttonSetUseUnderline.
buttonSetFocusOnClick
:: ButtonClass self
=> self
-> BoolfocusOnClick - whether the button grabs focus when clicked with the mouse
-> IO ()

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.

  • Available since Gtk version 2.4
buttonGetFocusOnClick
:: ButtonClass self
=> self
-> IO Boolreturns True if the button grabs focus when it is clicked with the mouse.

Returns whether the button grabs focus when it is clicked with the mouse. See buttonSetFocusOnClick.

  • Available since Gtk version 2.4
buttonSetAlignment
:: ButtonClass self
=> self
-> (Float, Float)(xalign, yalign) - the horizontal position of the child (0.0 is left aligned, 1.0 is right aligned) and the vertical position of the child (0.0 is top aligned, 1.0 is bottom aligned)
-> IO ()

Sets the alignment of the child. This has no effect unless the child derives from Misc or Aligment.

  • Available since Gtk version 2.4
buttonGetAlignment
:: ButtonClass self
=> self
-> IO (Float, Float)(xalign, yalign) - horizontal and vertical alignment

Gets the alignment of the child in the button.

  • Available since Gtk version 2.4
buttonGetImage
:: ButtonClass self
=> self
-> IO (Maybe Widget)a Widget or Nothing in case there is no image

Gets the widget that is currenty set as the image of the button. This may have been explicitly set by buttonSetImage or constructed by buttonNewFromStock.

  • Available since Gtk version 2.6
buttonSetImage
:: (ButtonClass self, WidgetClass image)
=> self
-> imagea widget to set as the image for the button
-> IO ()

Set the image of the button to the given widget. Note that it depends on the "gtk-button-images" setting whether the image will be displayed or not.

  • Available since Gtk+ version 2.6
Attributes
buttonLabel :: ButtonClass self => Attr self String

Text of the label widget inside the button, if the button contains a label widget.

Default value: ""

buttonUseUnderline :: ButtonClass self => Attr self Bool

If set, an underline in the text indicates the next character should be used for the mnemonic accelerator key.

Default value: False

buttonUseStock :: ButtonClass self => Attr self Bool

If set, the label is used to pick a stock item instead of being displayed.

Default value: False

buttonFocusOnClick :: ButtonClass self => Attr self Bool

Whether the button grabs focus when it is clicked with the mouse.

Default value: True

buttonRelief :: ButtonClass self => Attr self ReliefStyle

The border relief style.

Default value: ReliefNormal

buttonXalign :: ButtonClass self => Attr self Float

If the child of the button is a Misc or Alignment, this property can be used to control it's horizontal alignment. 0.0 is left aligned, 1.0 is right aligned.

Allowed values: [0,1]

Default value: 0.5

buttonYalign :: ButtonClass self => Attr self Float

If the child of the button is a Misc or Alignment, this property can be used to control it's vertical alignment. 0.0 is top aligned, 1.0 is bottom aligned.

Allowed values: [0,1]

Default value: 0.5

buttonImage :: (ButtonClass self, WidgetClass image) => ReadWriteAttr self (Maybe Widget) image

Child widget to appear next to the button text.

  • Available since Gtk version 2.6
Signals
onButtonActivate :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The button has been depressed (but not necessarily released yet). See clicked signal.
afterButtonActivate :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onClicked :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The button was clicked. This is only emitted if the mouse cursor was over the button when it was released.
afterClicked :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onEnter :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The cursor enters the button box.
afterEnter :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onLeave :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The cursor leaves the button box.
afterLeave :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onPressed :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The button is pressed.
afterPressed :: ButtonClass b => b -> IO () -> IO (ConnectId b)
onReleased :: ButtonClass b => b -> IO () -> IO (ConnectId b)
The button is released.
afterReleased :: ButtonClass b => b -> IO () -> IO (ConnectId b)
Produced by Haddock version 0.7