Qt logo

QButtonGroup Class Reference


The QButtonGroup widget organizes QButton widgets in a group. More...

#include <qbuttongroup.h>

Inherits QGroupBox.

Inherited by QHButtonGroup and QVButtonGroup.

List of all member functions.

Public Members

Signals

Protected Slots


Detailed Description

The QButtonGroup widget organizes QButton widgets in a group.

A button group widget makes it easier to deal with groups of buttons. A button in a button group is associated with a unique identifer. The button group emits a clicked() signal with this identifier when the button is clicked. Thus, a button group is an ideal solution when you have several similar buttons and want to connect all their clicked() signals, for example, to one slot.

An exclusive button group switches off all toggle buttons except the one that was clicked. A button group is by default non-exclusive. All radio buttons that are inserted, will be mutually exclusive even if the button group is non-exclusive.

There are two ways of using a button group:

  1. The button group is a parent widget of a number of buttons, i.e. the button group is the parent argument in the button constructor. The buttons are assigned identifiers 0, 1, 2 etc. in the order they are created. A QButtonGroup can display a frame and a title because it inherits QGroupBox.
  2. The button group is an invisible widget and the contained buttons have some other parent widget. A button must then be manually inserted using the insert() function with an identifer.

By default, the button group's setFont() and setPalette() functions do not change the appearance of the buttons, but you can use setFontPropagation() and setPalettePropagation() to change that.

See also: QButton, QPushButton, QCheckBox and QRadioButton.

Examples: tabdialog/tabdialog.cpp xform/xform.cpp drawdemo/drawdemo.cpp


Member Function Documentation

QButtonGroup::QButtonGroup(QWidget*parent=0, constchar*name=0)

Constructs a button group with no title.

The parent and name arguments are passed to the QWidget constructor.

QButtonGroup::QButtonGroup(constQString&title, QWidget*parent=0, constchar*name=0)

Constructs a button group with a title.

The parent and name arguments are passed to the QWidget constructor.

QButtonGroup::QButtonGroup(intstrips, Orientationorientation, QWidget*parent=0, constchar*name=0)

Constructs a button group with no title. Child widgets will be arranged in strips rows or columns (depending on orientation).

The parent and name arguments are passed to the QWidget constructor.

QButtonGroup::QButtonGroup(intstrips, Orientationorientation, constQString&title, QWidget*parent=0, constchar*name=0)

Constructs a button group with a title. Child widgets will be arranged in strips rows or columns (depending on orientation).

The parent and name arguments are passed to the QWidget constructor.

QButtonGroup::~QButtonGroup()

Destroys the button group and its child widgets.

voidQButtonGroup::buttonClicked() [protectedslot]

For internal use only.

voidQButtonGroup::buttonPressed() [protectedslot]

For internal use only.

voidQButtonGroup::buttonReleased() [protectedslot]

For internal use only.

voidQButtonGroup::buttonToggled(boolon) [protectedslot]

For internal use only.

voidQButtonGroup::clicked(intid) [signal]

This signal is emitted when a button in the group is clicked. The id argument is the button's identifier.

intQButtonGroup::count()const

Returns the number of buttons in the group.

QButton*QButtonGroup::find(intid)const

Finds and returns a pointer to the button with the specified identifier id.

Returns null if the button was not found.

intQButtonGroup::id(QButton*button)const

Returns the id of button, or -1 if button is not a member of this group.

intQButtonGroup::insert(QButton*button, intid=-1)

Inserts a button with the identifier id into the button group. Returns the button identifier.

It is not necessary to manually insert buttons that have this button group as their parent widget. An exception is when you want custom identifiers instead of the default 0, 1, 2 etc.

The button is assigned the identifier id or an automatically generated identifier. It works as follows: If id >= 0, this identifier is assigned. If id == -1 (default), the identifier is equal to the number of buttons in the group. If id is any other negative integer, for instance -2, a unique identifier (negative integer <= -2) is generated.

Inserting several buttons with id = -1 assigns the identifiers 0, 1, 2, etc.

See also: find(), remove() and setExclusive().

Examples: xform/xform.cpp

boolQButtonGroup::isExclusive()const

Returns TRUE if the button group is exclusive, otherwise FALSE.

See also: setExclusive().

boolQButtonGroup::isRadioButtonExclusive()const

Returns whether this button group will treat radio buttons as mutually exclusive.

See also: setRadioButtonExclusive().

voidQButtonGroup::moveFocus(intkey) [virtual]

Moves the keyboard focus according to key, and if appropriate checks the new focus item.

This function does nothing unless the keyboard focus points to one of the button group members and key is one of Key_Up, Key_Down, Key_Left and Key_Right.

voidQButtonGroup::pressed(intid) [signal]

This signal is emitted when a button in the group is pressed. The id argument is the button's identifier.

voidQButtonGroup::released(intid) [signal]

This signal is emitted when a button in the group is released. The id argument is the button's identifier.

voidQButtonGroup::remove(QButton*button)

Removes a button from the button group.

See also: insert().

QButton*QButtonGroup::selected()

Returns a pointer to the selected radio button in this group, if one exists, or 0 if there is no selected radio button in this group.

voidQButtonGroup::setButton(intid) [virtual]

Sets the button with id id to be on, and if this is an exclusive group, all other button in the group to be off.

voidQButtonGroup::setExclusive(boolenable) [virtual]

Sets the button group to be exclusive if enable is TRUE, or to be non-exclusive if enable is FALSE.

An exclusive button group switches off all other toggle buttons when one is switched on. This is ideal for groups of radio buttons. A non-exclusive group allow many buttons to be switched on at the same time.

The default setting is FALSE.

See also: isExclusive().

voidQButtonGroup::setRadioButtonExclusive(boolon) [virtual]

If on is TRUE, this button group will treat radio buttons as mutually exclusive, and other buttons according to isExclusive(). This function is called automatically whenever a QRadioButton is inserted, so you should normally never have to call it.


Search the documentation, FAQ, qt-interest archive and more (uses www.troll.no):


This file is part of the Qt toolkit, copyright © 1995-99 Troll Tech, all rights reserved.


Copyright 1999 Troll TechTrademarks
Qt version 2.0.2