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

QInputDialog Class

The QInputDialog class provides a simple convenience dialog to get a single value from the user.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

QInputDialog Class

  • Header: QInputDialog

  • CMake:

    find_package(Qt6 REQUIRED COMPONENTS Widgets)

    target_link_libraries(mytarget PRIVATE Qt6::Widgets)

  • qmake: QT += widgets

  • Inherits: QDialog

  • Group: QInputDialog is part of Standard Dialogs

Detailed Description

The input value can be a string, a number or an item from a list. A label must be set to tell the user what they should enter.

Five static convenience functions are provided: getText(), getMultiLineText(), getInt(), getDouble(), and getItem(). All the functions can be used in a similar way, for example:

 
Sélectionnez
    bool ok;
    QString text = QInputDialog::getText(this, tr("QInputDialog::getText()"),
                                         tr("User name:"), QLineEdit::Normal,
                                         QDir::home().dirName(), &ok);
    if (ok && !text.isEmpty())
        textLabel->setText(text);

The ok variable is set to true if the user clicks OK; otherwise, it is set to false.

Input Dialogs

The Standard Dialogs example shows how to use QInputDialog as well as other built-in Qt dialogs.

See Also

Member Type Documentation

 

enum QInputDialog::InputDialogOption

flags QInputDialog::InputDialogOptions

This enum specifies various options that affect the look and feel of an input dialog.

Constant

Value

Description

QInputDialog::NoButtons

0x00000001

Don't display OK and Cancel buttons (useful for "live dialogs").

QInputDialog::UseListViewForComboBoxItems

0x00000002

Use a QListView rather than a non-editable QComboBox for displaying the items set with setComboBoxItems().

QInputDialog::UsePlainTextEditForTextInput

0x00000004

Use a QPlainTextEdit for multiline text input. This value was introduced in 5.2.

The InputDialogOptions type is a typedef for QFlags<InputDialogOption>. It stores an OR combination of InputDialogOption values.

See Also

See also options, setOption(), testOption()

enum QInputDialog::InputMode

This enum describes the different modes of input that can be selected for the dialog.

Constant

Value

Description

QInputDialog::TextInput

0

Used to input text strings.

QInputDialog::IntInput

1

Used to input integers.

QInputDialog::DoubleInput

2

Used to input floating point numbers with double precision accuracy.

See Also

See also inputMode

Property Documentation

 

cancelButtonText : QString

This property holds the text for the button used to cancel the dialog

Access functions:

  • cancelButtonText() const

  • void setCancelButtonText(const &text)

comboBoxEditable : bool

This property holds whether or not the combo box used in the input dialog is editable

Access functions:

  • bool isComboBoxEditable() const

  • void setComboBoxEditable(bool editable)

comboBoxItems : QStringList

This property holds the items used in the combo box for the input dialog

Access functions:

  • comboBoxItems() const

  • void setComboBoxItems(const &items)

doubleDecimals : int

sets the precision of the double spinbox in decimals

Access functions:

  • int doubleDecimals() const

  • void setDoubleDecimals(int decimals)

See Also

doubleMaximum : double

This property holds the maximum double precision floating point value accepted as input

This property is only relevant when the input dialog is used in DoubleInput mode.

Access functions:

  • double doubleMaximum() const

  • void setDoubleMaximum(double max)

doubleMinimum : double

This property holds the minimum double precision floating point value accepted as input

This property is only relevant when the input dialog is used in DoubleInput mode.

Access functions:

  • double doubleMinimum() const

  • void setDoubleMinimum(double min)

doubleStep : double

This property holds the step by which the double value is increased and decreased

This property is only relevant when the input dialog is used in DoubleInput mode.

Access functions:

  • double doubleStep() const

  • void setDoubleStep(double step)

doubleValue : int

This property holds the current double precision floating point value accepted as input

This property is only relevant when the input dialog is used in DoubleInput mode.

Access functions:

  • double doubleValue() const

  • void setDoubleValue(double value)

Notifier signal:

inputMode : InputMode

This property holds the mode used for input

This property helps determine which widget is used for entering input into the dialog.

Access functions:

  • inputMode() const

  • void setInputMode( mode)

intMaximum : int

This property holds the maximum integer value accepted as input

This property is only relevant when the input dialog is used in IntInput mode.

Access functions:

  • int intMaximum() const

  • void setIntMaximum(int max)

intMinimum : int

This property holds the minimum integer value accepted as input

This property is only relevant when the input dialog is used in IntInput mode.

Access functions:

  • int intMinimum() const

  • void setIntMinimum(int min)

intStep : int

This property holds the step by which the integer value is increased and decreased

This property is only relevant when the input dialog is used in IntInput mode.

Access functions:

  • int intStep() const

  • void setIntStep(int step)

intValue : int

This property holds the current integer value accepted as input

This property is only relevant when the input dialog is used in IntInput mode.

Access functions:

  • int intValue() const

  • void setIntValue(int value)

Notifier signal:

labelText : QString

This property holds the label's text which describes what needs to be input

Access functions:

  • labelText() const

  • void setLabelText(const &text)

okButtonText : QString

This property holds the text for the button used to accept the entry in the dialog

Access functions:

  • okButtonText() const

  • void setOkButtonText(const &text)

options : InputDialogOptions

This property holds the various options that affect the look and feel of the dialog

By default, all options are disabled.

Access functions:

  • options() const

  • void setOptions( options)

See Also

See also setOption(), testOption()

textEchoMode : QLineEdit::EchoMode

This property holds the echo mode for the text value

This property is only relevant when the input dialog is used in TextInput mode.

Access functions:

  • textEchoMode() const

  • void setTextEchoMode( mode)

textValue : QString

This property holds the text value for the input dialog

This property is only relevant when the input dialog is used in TextInput mode.

Access functions:

  • textValue() const

  • void setTextValue(const &text)

Notifier signal:

Member Function Documentation

 

QInputDialog::QInputDialog(QWidget *parent = nullptr, Qt::WindowFlags flags = Qt::WindowFlags())

Constructs a new input dialog with the given parent and window flags.

[virtual] QInputDialog::~QInputDialog()

Destroys the input dialog.

[override virtual] void QInputDialog::done(int result)

Reimplements: QDialog::done(int r).

Closes the dialog and sets its result code to result. If this dialog is shown with exec(), done() causes the local event loop to finish, and exec() to return result.

See Also

See also QDialog::done()

void QInputDialog::doubleValueChanged(double value)

This signal is emitted whenever the double value changes in the dialog. The current value is specified by value.

This signal is only relevant when the input dialog is used in DoubleInput mode.

Notifier signal for property doubleValue.

void QInputDialog::doubleValueSelected(double value)

This signal is emitted whenever the user selects a double value by accepting the dialog; for example, by clicking the OK button. The selected value is specified by value.

This signal is only relevant when the input dialog is used in DoubleInput mode.

[static] double QInputDialog::getDouble(QWidget *parent, const QString &title, const QString &label, double value = 0, double min = -2147483647, double max = 2147483647, int decimals = 1, bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags(), double step = 1)

Static convenience function to get a floating point number from the user.

title is the text which is displayed in the title bar of the dialog. label is the text which is shown to the user (it should say what should be entered). value is the default floating point number that the line edit will be set to. min and max are the minimum and maximum values the user may choose. decimals is the maximum number of decimal places the number may have. step is the amount by which the values change as the user presses the arrow buttons to increment or decrement the value.

If ok is nonnull, *ok will be set to true if the user pressed OK and to false if the user pressed Cancel. The dialog's parent is parent. The dialog will be modal and uses the widget flags.

This function returns the floating point number which has been entered by the user.

Use this static function like this:

 
Sélectionnez
    bool ok;
    double d = QInputDialog::getDouble(this, tr("QInputDialog::getDouble()"),
                                       tr("Amount:"), 37.56, -10000, 10000, 2, &amp;ok,
                                       Qt::WindowFlags(), 1);
    if (ok)
        doubleLabel-&gt;setText(QString("$%1").arg(d));
See Also

See also getText(), getInt(), getItem(), getMultiLineText()

[static] int QInputDialog::getInt(QWidget *parent, const QString &title, const QString &label, int value = 0, int min = -2147483647, int max = 2147483647, int step = 1, bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags())

Static convenience function to get an integer input from the user.

title is the text which is displayed in the title bar of the dialog. label is the text which is shown to the user (it should say what should be entered). value is the default integer which the spinbox will be set to. min and max are the minimum and maximum values the user may choose. step is the amount by which the values change as the user presses the arrow buttons to increment or decrement the value.

If ok is nonnull *ok will be set to true if the user pressed OK and to false if the user pressed Cancel. The dialog's parent is parent. The dialog will be modal and uses the widget flags.

On success, this function returns the integer which has been entered by the user; on failure, it returns the initial value.

Use this static function like this:

 
Sélectionnez
    bool ok;
    int i = QInputDialog::getInt(this, tr("QInputDialog::getInt()"),
                                 tr("Percentage:"), 25, 0, 100, 1, &amp;ok);
    if (ok)
        integerLabel-&gt;setText(tr("%1%").arg(i));
See Also

[static] QString QInputDialog::getItem(QWidget *parent, const QString &title, const QString &label, const QStringList &items, int current = 0, bool editable = true, bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags(), Qt::InputMethodHints inputMethodHints = Qt::ImhNone)

Static convenience function to let the user select an item from a string list.

title is the text which is displayed in the title bar of the dialog. label is the text which is shown to the user (it should say what should be entered). items is the string list which is inserted into the combo box. current is the number of the item which should be the current item. inputMethodHints is the input method hints that will be used if the combo box is editable and an input method is active.

If editable is true the user can enter their own text; otherwise, the user may only select one of the existing items.

If ok is nonnull *ok will be set to true if the user pressed OK and to false if the user pressed Cancel. The dialog's parent is parent. The dialog will be modal and uses the widget flags.

This function returns the text of the current item, or if editable is true, the current text of the combo box.

Use this static function like this:

 
Sélectionnez
    QStringList items;
    items &lt;&lt; tr("Spring") &lt;&lt; tr("Summer") &lt;&lt; tr("Fall") &lt;&lt; tr("Winter");

    bool ok;
    QString item = QInputDialog::getItem(this, tr("QInputDialog::getItem()"),
                                         tr("Season:"), items, 0, false, &amp;ok);
    if (ok &amp;&amp; !item.isEmpty())
        itemLabel-&gt;setText(item);
See Also

[static] QString QInputDialog::getMultiLineText(QWidget *parent, const QString &title, const QString &label, const QString &text = QString(), bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags(), Qt::InputMethodHints inputMethodHints = Qt::ImhNone)

Static convenience function to get a multiline string from the user.

title is the text which is displayed in the title bar of the dialog. label is the text which is shown to the user (it should say what should be entered). text is the default text which is placed in the plain text edit. inputMethodHints is the input method hints that will be used in the edit widget if an input method is active.

If ok is nonnull *ok will be set to true if the user pressed OK and to false if the user pressed Cancel. The dialog's parent is parent. The dialog will be modal and uses the specified widget flags.

If the dialog is accepted, this function returns the text in the dialog's plain text edit. If the dialog is rejected, a null QString is returned.

Use this static function like this:

 
Sélectionnez
    bool ok;
    QString text = QInputDialog::getMultiLineText(this, tr("QInputDialog::getMultiLineText()"),
                                                  tr("Address:"), "John Doe\nFreedom Street", &amp;ok);
    if (ok &amp;&amp; !text.isEmpty())
        multiLineTextLabel-&gt;setText(text);
See Also

See also getInt(), getDouble(), getItem(), getText()

[static] QString QInputDialog::getText(QWidget *parent, const QString &title, const QString &label, QLineEdit::EchoMode mode = QLineEdit::Normal, const QString &text = QString(), bool *ok = nullptr, Qt::WindowFlags flags = Qt::WindowFlags(), Qt::InputMethodHints inputMethodHints = Qt::ImhNone)

Static convenience function to get a string from the user.

title is the text which is displayed in the title bar of the dialog. label is the text which is shown to the user (it should say what should be entered). text is the default text which is placed in the line edit. mode is the echo mode the line edit will use. inputMethodHints is the input method hints that will be used in the edit widget if an input method is active.

If ok is nonnull *ok will be set to true if the user pressed OK and to false if the user pressed Cancel. The dialog's parent is parent. The dialog will be modal and uses the specified widget flags.

If the dialog is accepted, this function returns the text in the dialog's line edit. If the dialog is rejected, a null QString is returned.

Use this static function like this:

 
Sélectionnez
    bool ok;
    QString text = QInputDialog::getText(this, tr("QInputDialog::getText()"),
                                         tr("User name:"), QLineEdit::Normal,
                                         QDir::home().dirName(), &amp;ok);
    if (ok &amp;&amp; !text.isEmpty())
        textLabel-&gt;setText(text);
See Also

void QInputDialog::intValueChanged(int value)

This signal is emitted whenever the integer value changes in the dialog. The current value is specified by value.

This signal is only relevant when the input dialog is used in IntInput mode.

Notifier signal for property intValue.

void QInputDialog::intValueSelected(int value)

This signal is emitted whenever the user selects a integer value by accepting the dialog; for example, by clicking the OK button. The selected value is specified by value.

This signal is only relevant when the input dialog is used in IntInput mode.

[override virtual] QSize QInputDialog::minimumSizeHint() const

void QInputDialog::open(QObject *receiver, const char *member)

This function connects one of its signals to the slot specified by receiver and member. The specific signal depends on the arguments that are specified in member. These are:

The signal will be disconnected from the slot when the dialog is closed.

void QInputDialog::setDoubleRange(double min, double max)

Sets the range of double precision floating point values accepted by the dialog when used in DoubleInput mode, with minimum and maximum values specified by min and max respectively.

void QInputDialog::setIntRange(int min, int max)

Sets the range of integer values accepted by the dialog when used in IntInput mode, with minimum and maximum values specified by min and max respectively.

void QInputDialog::setOption(QInputDialog::InputDialogOption option, bool on = true)

Sets the given option to be enabled if on is true; otherwise, clears the given option.

See Also

See also options, testOption()

[override virtual] void QInputDialog::setVisible(bool visible)

[override virtual] QSize QInputDialog::sizeHint() const

Reimplements: QDialog::sizeHint() const.

bool QInputDialog::testOption(QInputDialog::InputDialogOption option) const

Returns true if the given option is enabled; otherwise, returns false.

See Also

See also options, setOption()

void QInputDialog::textValueChanged(const QString &text)

This signal is emitted whenever the text string changes in the dialog. The current string is specified by text.

This signal is only relevant when the input dialog is used in TextInput mode.

Notifier signal for property textValue.

void QInputDialog::textValueSelected(const QString &text)

This signal is emitted whenever the user selects a text string by accepting the dialog; for example, by clicking the OK button. The selected string is specified by text.

This signal is only relevant when the input dialog is used in TextInput mode.

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