0


Qt QMessageBox详解

文章目录

一.QMessageBox介绍

文本消息显示框(message box)向用户发出情况警报信息并进一步解释警报或向用户提问,以及可选的详细文本以在用户请求时提供更多数据。

枚举

枚举枚举值enumButtonRole { InvalidRole, AcceptRole, RejectRole, DestructiveRole, ActionRole, …, ResetRole }enumIcon { NoIcon, Question, Information, Warning, Critical }enumStandardButton { Ok, Open, Save, Cancel, Close, …, ButtonMask }flagsStandardButtons

属性

属性名称类型detailedTextQStringstandardButtonsStandardButtonsiconIconiconPixmapQPixmapinformativeTextQStringtextQStringtextFormatQt::TextFormattextInteractionFlagsQt::TextInteractionFlags

函数

返回值函数原型说明QMessageBox(QMessageBox::Icon icon, const QString &title, const QString &text, QMessageBox::StandardButtons buttons = NoButton, QWidget *parent = nullptr, Qt::WindowFlags f = Qt::DialogQt::MSWindowsFixedSizeDialogHint)QMessageBox(QWidget *parent = nullptr)构造函数virtual~QMessageBox()析构函数voidaddButton(QAbstractButton *button, QMessageBox::ButtonRole role)添加按钮到消息框中QPushButton *addButton(const QString &text, QMessageBox::ButtonRole role)添加按钮到消息框中QPushButton *addButton(QMessageBox::StandardButton button)添加按钮到消息框中QAbstractButton *button(QMessageBox::StandardButton which) const返回与标准按钮对应的指针,如果此消息框中不存在标准按钮,则返回nullptrQMessageBox::ButtonRolebuttonRole(QAbstractButton *button) const返回指定按钮的按钮角色。如果按钮为nullptr或尚未添加到消息框,则此函数返回InvalidRole。QList<QAbstractButton *>buttons() const返回已添加到消息框中的所有按钮的列表。QCheckBox *checkBox() const返回对话框上显示的复选框。如果未设置任何复选框,则为nullptr。QAbstractButton *clickedButton() const返回用户单击的按钮,如果用户按Esc键且未设置转义按钮,则返回nullptr。QPushButton *defaultButton() const返回应该是消息框默认按钮的按钮。如果未设置默认按钮,则返回nullptr。QStringdetailedText() const保存要显示在详细信息区域中的文本。QAbstractButton *escapeButton() const返回按下转义时激活的按钮。QMessageBox::Iconicon() const保存消息框的图标QPixmapiconPixmap() const保存当前图标QStringinformativeText() const包含为消息提供更完整描述的信息性文本voidopen(QObject *receiver, const char *member)打开对话框并将其 finished()或 buttonClicked()信号连接到接收器和成员指定的插槽。如果slot-in成员的第一个参数有一个指针,则连接到 buttonClicked(),否则连接到finished()。voidremoveButton(QAbstractButton *button)从按钮框中删除按钮而不删除它。voidsetCheckBox(QCheckBox *cb)设置消息对话框上的复选框cb。消息框获取复选框的所有权。参数cb可以是nullptr,以从消息框中删除现有复选框。voidsetDefaultButton(QPushButton *button)将消息框的默认按钮设置为按钮。voidsetDefaultButton(QMessageBox::StandardButton button)将消息框的默认按钮设置为按钮。voidsetDetailedText(const QString &text)保存要显示在详细信息区域中的文本。voidsetEscapeButton(QAbstractButton *button)将按下Escape键时激活的按钮设置为按钮。voidsetEscapeButton(QMessageBox::StandardButton button)将按下Escape键时激活的按钮设置为按钮。voidsetIcon(QMessageBox::Icon)保存消息框的图标voidsetIconPixmap(const QPixmap &pixmap)保存消息框的图标voidsetInformativeText(const QString &text)保存要显示的消息框文本voidsetStandardButtons(QMessageBox::StandardButtons buttons)根据文本格式设置(QMessageBox::textFormat),文本将被解释为纯文本或富文本。默认设置为 Qt::AutoText,,即消息框将尝试自动检测文本的格式。voidsetText(const QString &text)保存要显示的消息框文本voidsetTextFormat(Qt::TextFormat format)保存消息框显示的文本格式voidsetTextInteractionFlags(Qt::TextInteractionFlags flags)voidsetWindowModality(Qt::WindowModality windowModality)voidsetWindowTitle(const QString &title)QMessageBox::StandardButtonstandardButton(QAbstractButton *button) const返回与给定按钮对应的标准按钮枚举值,如果给定按钮不是标准按钮,则返回NoButton。QMessageBox::StandardButtonsstandardButtons() const返回与给定按钮对应的标准按钮枚举值,如果给定按钮不是标准按钮,则返回NoButton。QStringtext() const保存要显示的消息框文本Qt::TextFormattextFormat() const保存消息框显示的文本格式Qt::TextInteractionFlagstextInteractionFlags() const

二.QMessageBox的用法

1.导入QMessage库

#include<QMessageBox>

2.弹窗提示

构造QMessageBox的实例,设置所需显示的消息,然后调用

exec()

来显示消息。用户必须单击“确定”按钮以关闭消息框。GUI的其余部分将被阻止,直到消息框被关闭。

QMessageBox msgBox;
msgBox.setText(u8"你好~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~");
msgBox.exec();

在这里插入图片描述

3.提供选项的弹窗提示

一个比仅仅提醒用户事件更好的方法是询问用户该怎么做。将问题存储在信息性文本属性中,并将标准按钮属性设置为所需的按钮集作为用户响应集。通过使用位或运算符组合

StandardButtons

中的值来指定按钮。按钮的显示顺序取决于平台。例如,在Windows上,“保存”显示在“取消”的左侧,而在Mac OS上,顺序相反。要向用户提供更多信息以帮助他回答问题,通过

setDetailedText

设置详细文本属性。如果设置了详细文本属性,则显示详细信息按钮。

exec()

槽返回单击的按钮的

StandardButtons

值。

QMessageBox msgBox;
msgBox.setText(u8"该文档已被修改.");
msgBox.setDetailedText(u8"这里是详细的提示信息");
msgBox.setInformativeText(u8"是否要保存你的修改?");
msgBox.setStandardButtons(QMessageBox::Save | QMessageBox::Discard | QMessageBox::Cancel);
msgBox.setDefaultButton(QMessageBox::Save);int ret = msgBox.exec();switch(ret){case QMessageBox::Save:qDebug()<<"save";break;case QMessageBox::Discard:qDebug()<<"Discard";break;case QMessageBox::Cancel:qDebug()<<"Cancel";break;default:qDebug()<<"default";break;}

在这里插入图片描述

4.作为提示,报警,报错提示窗口

int ret =QMessageBox::information(this,tr(u8"信息提示"),tr(u8"该文档已被修改.\n"
                                  u8"是否要保存你的修改?"),
                               QMessageBox::Ok | QMessageBox::Cancel | QMessageBox::Help);

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
对于窗口的类型,有以下几种可以选择:
内容值说明

QMessageBox::NoIcon
0

the message box does not have any icon.

QMessageBox::Question
4

an icon indicating that the message is asking a question.

QMessageBox::Information
1

an icon indicating that the message is nothing out of the ordinary.

QMessageBox::Warning
2

an icon indicating that the message is a warning, but can be dealt with.

QMessageBox::Critical
3

an icon indicating that the message represents a critical problem.
对于窗口中的按钮,有以下几种可以选择:
内容值说明

QMessageBox::Ok
0x00000400

An “OK” button defined with the AcceptRole.

QMessageBox::Open
0x00002000

An “Open” button defined with the AcceptRole.

QMessageBox::Save
0x00000800

A “Save” button defined with the AcceptRole.

QMessageBox::Cancel
0x00400000

A “Cancel” button defined with the RejectRole.

QMessageBox::Close
0x00200000

A “Close” button defined with the RejectRole.

QMessageBox::Discard
0x00800000

A “Discard” or “Don’t Save” button, depending on the platform, defined with the DestructiveRole.

QMessageBox::Apply
0x02000000

An “Apply” button defined with the ApplyRole.

QMessageBox::Reset
0x04000000

A “Reset” button defined with the ResetRole.

QMessageBox::RestoreDefaults
0x08000000

A “Restore Defaults” button defined with the ResetRole.

QMessageBox::Help
0x01000000

A “Help” button defined with the HelpRole.

QMessageBox::SaveAll
0x00001000

A “Save All” button defined with the AcceptRole.

QMessageBox::Yes
0x00004000

A “Yes” button defined with the YesRole.

QMessageBox::YesToAll
0x00008000

A “Yes to All” button defined with the YesRole.

QMessageBox::No
0x00010000

A “No” button defined with the NoRole.

QMessageBox::NoToAll
0x00020000

A “No to All” button defined with the NoRole.

QMessageBox::Abort
0x00040000

An “Abort” button defined with the RejectRole.

QMessageBox::Retry
0x00080000

A “Retry” button defined with the AcceptRole.

QMessageBox::Ignore
0x00100000

An “Ignore” button defined with the AcceptRole.

QMessageBox::NoButton
0x00000000

An invalid button.

标签: qt ui

本文转载自: https://blog.csdn.net/qq_30150579/article/details/129293823
版权归原作者 AoDeLuo 所有, 如有侵权,请联系我们删除。

“Qt QMessageBox详解”的评论:

还没有评论