找回密码
 立即注册
收起左侧

Qt学习之路第15篇 标准对话框 QMessageBox

8
回复
28405
查看
[复制链接]
累计签到:3 天
连续签到:1 天
来源: 2013-9-9 11:58:06 显示全部楼层 |阅读模式
版权声明

该文章原创于Qter开源社区(www.qter.org),作者devbean,博客www.devbean.net,转载请注明出处!


所谓标准对话框,是 Qt 内置的一系列对话框,用于简化开发。事实上,有很多对话框都是通用的,比如打开文件、设置颜色、打印设置等。这些对话框在所有程序中几乎相同,因此没有必要在每一个程序中都自己实现这么一个对话框。


Qt 的内置对话框大致分为以下几类:



  • QColorDialog:选择颜色;
  • QFileDialog:选择文件或者目录;
  • QFontDialog:选择字体;
  • QInputDialog:允许用户输入一个值,并将其值返回;
  • QMessageBox:模态对话框,用于显示信息、询问问题等;
  • QPageSetupDialog:为打印机提供纸张相关的选项;
  • QPrintDialog:打印机配置;
  • QPrintPreviewDialog:打印预览;
  • QProgressDialog:显示操作过程。


这里我们简单地介绍一下标准对话框 QMessageBox 的使用。在前面有了关于对话框的基础之上,应该可以结合文档很轻松地学习如何使用 Qt 的标准对话框。其它种类的标准对话框,我们将在后面的章节中再一一介绍。


QMessageBox 用于显示消息提示。我们一般会使用其提供的几个 static 函数:



  • void about(QWidget * parent, const QString & title, const QString & text):显示关于对话框。这是一个最简单的对话框,其标题是 title,内容是 text,父窗口是 parent。对话框只有一个 OK 按钮。

  • void aboutQt(QWidget * parent, const QString & title = QString()):显示关于 Qt 对话框。该对话框用于显示有关 Qt 的信息。

  • StandardButton critical(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton):显示严重错误对话框。这个对话框将显示一个红色的错误符号。我们可以通过 buttons 参数指明其显示的按钮。默认情况下只有一个 Ok 按钮,我们可以使用 StandardButtons 类型指定多种按钮。

  • StandardButton information(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton):QMessageBox::information() 函数与 QMessageBox::critical() 类似,不同之处在于这个对话框提供一个普通信息图标。

  • StandardButton question(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = StandardButtons( Yes | No ), StandardButton defaultButton = NoButton):QMessageBox::question() 函数与 QMessageBox::critical() 类似,不同之处在于这个对话框提供一个问号图标,并且其显示的按钮是“是”和“否”两个。

  • StandardButton warning(QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton):QMessageBox::warning() 函数与 QMessageBox::critical() 类似,不同之处在于这个对话框提供一个**叹号图标。


我们可以通过下面的代码来演示下如何使用 QMessageBox。

  1. if (QMessageBox::Yes == QMessageBox::question(this,
  2.                                               tr("Question"),
  3.                                               tr("Are you OK?"),
  4.                                               QMessageBox::Yes | QMessageBox::No,
  5.                                               QMessageBox::Yes)) {
  6.     QMessageBox::information(this, tr("Hmmm..."), tr("I'm glad to hear that!"));
  7. } else {
  8.     QMessageBox::information(this, tr("Hmmm..."), tr("I'm sorry!"));
  9. }
复制代码

我们使用 QMessageBox::question() 来询问一个问题。这个对话框的父窗口是 this,也就是我们的 MainWindow(或者其他 QWidget 指针)。QMessageBox 是 QDialog 的子类,这意味着它的初始显示位置将会是在 parent 窗口的中央(我们在前面的章节中提到过这一点)。第二个参数是对话框的标题。第三个参数是我们想要显示的内容。这里就是我们需要询问的文字。下面,我们使用或运算符(|)指定对话框应该出现的按钮。这里我们希望是一个 Yes 和一个 No。最后一个参数指定默认选择的按钮。这个函数有一个返回值,用于确定用户点击的是哪一个按钮。按照我们的写法,应该很容易的看出,这是一个模态对话框,因此我们可以直接获取其返回值。如果返回值是 Yes,也就是说用户点击了 Yes 按钮,我们显示一个普通消息对话框,显示“I’m glad to hear that!”,否则则显示“I’m sorry!”。运行一下我们的程序片段,就可以看到其中的不同:



QMessageBox 类的 static 函数优点是方便使用,缺点也很明显:非常不灵活。我们只能使用简单的几种形式。为了能够定制 QMessageBox 细节,我们必须使用 QMessageBox 的属性设置 API。如果我们希望制作一个询问是否保存的对话框,我们可以使用如下的代码:

  1. QMessageBox msgBox;
  2. msgBox.setText(tr("The document has been modified."));
  3. msgBox.setInformativeText(tr("Do you want to save your changes?"));
  4. msgBox.setDetailedText(tr("Differences here..."));
  5. msgBox.setStandardButtons(QMessageBox::Save
  6.                           | QMessageBox::Discard
  7.                           | QMessageBox::Cancel);
  8. msgBox.setDefaultButton(QMessageBox::Save);
  9. int ret = msgBox.exec();
  10. switch (ret) {
  11. case QMessageBox::Save:
  12.     qDebug() << "Save document!";
  13.     break;
  14. case QMessageBox::Discard:
  15.     qDebug() << "Discard changes!";
  16.     break;
  17. case QMessageBox::Cancel:
  18.     qDebug() << "Close document!";
  19.     break;
  20. }
复制代码

msgBox 是一个建立在栈上的 QMessageBox 实例。我们设置其标题为“The document has been modified.”,informationText 则是会在对话框中显示的文字。下面我们使用了一个 detailedText,也就是详细信息,当我们点击了详细信息按钮时,对话框可以自动显示更多信息。我们自己定义的对话框的按钮有三个:保存、丢弃和取消。然后我们使用了 exec() 是其成为一个模态对话框,根据其返回值进行相应的操作。


同时在 KDE 和 Windows 7 上编译运行一下上面的代码,我们可以看到一些区别:






除去对话框样式,我们值得注意的是 QMessageBox 下方按钮的排列顺序。KDE 上是 Show Details…、Save、Discard 和 Cancel;而 Windows 7 上则是 Save、Discard、Show Details… 和 Cancel。我们并没有指定按钮的顺序,Qt 已经帮我们按照不同平台的使用习惯对其进行了调整。这一点在 Mac OS 上也会有相应的体现。对于一个普通的 QDialog 而言,Qt 使用的是 QDialogButtonBox 这个类来实现不同平台的对话框按钮顺序的显示的。更多细节请参考这个类的文档。









本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
回复

使用道具 举报

累计签到:17 天
连续签到:1 天
2014-8-22 16:25:12 显示全部楼层
KDE是什么,怎么能够显示按钮图标呢?
回复 支持 反对

使用道具 举报

累计签到:3 天
连续签到:1 天
2015-11-14 13:32:19 显示全部楼层
感觉省略了好多东西~~~
回复 支持 反对

使用道具 举报

累计签到:20 天
连续签到:1 天
2016-5-26 23:55:02 显示全部楼层
每天学习一点,每天进步多一点!
回复 支持 反对

使用道具 举报

累计签到:10 天
连续签到:1 天
2017-7-17 11:35:35 显示全部楼层
打出来一大堆错误,错误提示都看不懂
回复 支持 反对

使用道具 举报

累计签到:5 天
连续签到:1 天
2018-4-25 10:41:01 显示全部楼层
这里是拿前面的工具栏窗口程序修改的,主要讨论open()内部子程序,编译出错显示无效使用QDebug,只要mainWindows头文件包含QDebug就行
回复 支持 反对

使用道具 举报

累计签到:11 天
连续签到:1 天
2018-9-3 15:48:31 显示全部楼层
huang98778 发表于 2018-4-25 10:41
这里是拿前面的工具栏窗口程序修改的,主要讨论open()内部子程序,编译出错显示无效使用QDebug,只要main ...

明白人,其实就第一个Qt程序用到现在,都不用新建项目。
回复 支持 反对

使用道具 举报

尚未签到

2018-10-24 11:20:35 显示全部楼层
点击show detail有显示,save和discard没有显示,怎么回事?
回复 支持 反对

使用道具 举报

尚未签到

2019-4-3 10:38:09 显示全部楼层
每天进步一点点,学习学习
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

公告
可以关注我们的微信公众号yafeilinux_friends获取最新动态,或者加入QQ会员群进行交流:190741849、186601429(已满) 我知道了