IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

ButtonGroup QML Type

Mutually-exclusive group of checkable buttons.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

ButtonGroup QML Type

  • Import Statement: import QtQuick.Controls

  • Inherits:: QtObject

  • Group: ButtonGroup is part of utilities

I. Detailed Description

ButtonGroup is a non-visual, mutually exclusive group of buttons. It is used with controls such as RadioButton, where only one of the options can be selected at a time.

The most straight-forward way to use ButtonGroup is to assign a list of buttons. For example, the list of children of a positioner or a layout that manages a group of mutually exclusive buttons.

 
Sélectionnez
ButtonGroup {
    buttons: column.children
}

Column {
    id: column

    RadioButton {
        checked: true
        text: qsTr("DAB")
    }

    RadioButton {
        text: qsTr("FM")
    }

    RadioButton {
        text: qsTr("AM")
    }
}

Mutually exclusive buttons do not always share the same parent item, or the parent layout may sometimes contain items that should not be included in the button group. Such cases are best handled using the group attached property.

 
Sélectionnez
ButtonGroup { id: radioGroup }

Column {
    Label {
        text: qsTr("Radio:")
    }

    RadioButton {
        checked: true
        text: qsTr("DAB")
        ButtonGroup.group: radioGroup
    }

    RadioButton {
        text: qsTr("FM")
        ButtonGroup.group: radioGroup
    }

    RadioButton {
        text: qsTr("AM")
        ButtonGroup.group: radioGroup
    }
}

More advanced use cases can be handled using the addButton() and removeButton() methods.

I-1. See Also

II. Property Documentation

 

II-1. buttons : list<AbstractButton>

This property holds the list of buttons.

 
Sélectionnez
ButtonGroup {
    buttons: column.children
}

Column {
    id: column

    RadioButton {
        checked: true
        text: qsTr("Option A")
    }

    RadioButton {
        text: qsTr("Option B")
    }
}
II-1-1. See Also

See also group

II-2. [since QtQuick.Controls 2.4 (Qt 5.11)] checkState : enumeration

This property holds the combined check state of the button group.

Available states:

Constant

Description

Qt.Unchecked

None of the buttons are checked.

Qt.PartiallyChecked

Some of the buttons are checked.

Qt.Checked

All of the buttons are checked.

Setting the check state of a non-exclusive button group to Qt.Unchecked or Qt.Checked unchecks or checks all buttons in the group, respectively. Qt.PartiallyChecked is ignored.

Setting the check state of an exclusive button group to Qt.Unchecked unchecks the checkedButton. Qt.Checked and Qt.PartiallyChecked are ignored.

This property was introduced in QtQuick.Controls 2.4 (Qt 5.11).

II-3. checkedButton : AbstractButton

This property holds the currently selected button in an exclusive group, or null if there is none or the group is non-exclusive.

By default, it is the first checked button added to an exclusive button group.

II-3-1. See Also

See also exclusive

II-4. [since QtQuick.Controls 2.3 (Qt 5.10)] exclusive : bool

This property holds whether the button group is exclusive. The default value is true.

If this property is true, then only one button in the group can be checked at any given time. The user can click on any button to check it, and that button will replace the existing one as the checked button in the group.

In an exclusive group, the user cannot uncheck the currently checked button by clicking on it; instead, another button in the group must be clicked to set the new checked button for that group.

In a non-exclusive group, checking and unchecking buttons does not affect the other buttons in the group. Furthermore, the value of the checkedButton property is null.

This property was introduced in QtQuick.Controls 2.3 (Qt 5.10).

III. Attached Property Documentation

 

III-1. ButtonGroup.group : ButtonGroup

This property attaches a button to a button group.

 
Sélectionnez
ButtonGroup { id: group }

RadioButton {
    checked: true
    text: qsTr("Option A")
    ButtonGroup.group: group
}

RadioButton {
    text: qsTr("Option B")
    ButtonGroup.group: group
}
III-1-1. See Also

See also buttons

IV. Signal Documentation

 

IV-1. [since QtQuick.Controls 2.1 (Qt 5.8)] clicked(AbstractButton button)

This signal is emitted when a button in the group has been clicked.

This signal is convenient for implementing a common signal handler for all buttons in the same group.

 
Sélectionnez
ButtonGroup {
    buttons: column.children
    onClicked: console.log("clicked:", button.text)
}

Column {
    id: column
    Button { text: "First" }
    Button { text: "Second" }
    Button { text: "Third" }
}

The corresponding handler is onClicked.

This signal was introduced in QtQuick.Controls 2.1 (Qt 5.8).

IV-1-1. See Also

V. Method Documentation

 

V-1. void addButton(AbstractButton button)

Adds a button to the button group.

Manually adding objects to a button group is typically unnecessary. The buttons property and the group attached property provide a convenient and declarative syntax.

V-1-1. See Also

See also buttons, group

V-2. void removeButton(AbstractButton button)

Removes a button from the button group.

Manually removing objects from a button group is typically unnecessary. The buttons property and the group attached property provide a convenient and declarative syntax.

V-2-1. See Also

See also buttons, group

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+