Qt学习之路(17): Qt标准对话框之QMessageBox

很久没有更新博客,主要是公司里面还在验收一些东西,因此没有及时更新。并且也在写一个基于Qt的画图程序,基本上相似于PS的东西,主要用到的是Qt Graphics View Framework。好了,如今仍是继续来讲说Qt的标准对话框吧!
 
此次来讲一下QMessageBox以及相似的几种对话框。其实,咱们已经用过QMessageBox了,就在以前的几个程序中。不过,当时是大略的说了一下,如今专门来讲说这几种对话框。
 
先来看一下最熟悉的QMessageBox::information。咱们在之前的代码中这样使用过:
 
QMessageBox::information(NULL, "Title", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
 
下面是一个简单的例子:
 
 
如今咱们从API中看看它的函数签名:
 
static StandardButton QMessageBox::information ( QWidget * parent, const QString & title, const QString & text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton );
 
首先,它是static的,因此咱们可以使用类名直接访问到(怎么看都像废话…);而后看它那一堆参数,第一个参数parent,说明它的父组件;第二个参数title,也就是对话框的标题;第三个参数text,是对话框显示的内容;第四个参数buttons,声明对话框放置的按钮,默认是只放置一个OK按钮,这个参数可使用或运算,例如咱们但愿有一个Yes和一个No的按钮,可使用 QMessageBox::Yes | QMessageBox::No,全部的按钮类型能够在QMessageBox声明的StandarButton枚举中找到;第五个参数defaultButton就是默认选中的按钮,默认值是NoButton,也就是哪一个按钮都不选中。这么多参数,豆子也是记不住的啊!因此,咱们在用QtCreator写的时候,能够在输入QMessageBox::information以后输入(,稍等一下,QtCreator就会帮咱们把函数签名显示在右上方了,仍是挺方便的一个功能!
 
Qt提供了五个相似的接口,用于显示相似的窗口。具体代码这里就不作介绍,只是来看一下样子吧!
 
QMessageBox::critical(NULL, "critical", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
 
 
QMessageBox::warning(NULL, "warning", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
 
 
QMessageBox::question(NULL, "question", "Content", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
 
 
QMessageBox::about(NULL, "About", "About this application");
 
 
请注意,最后一个about()函数是没有后两个关于button设置的按钮的!
 
QMessageBox对话框的文本信息时能够支持HTML标签的。例如:
 
QMessageBox::about(NULL, "About", "About this <font color='red'>application</font>");
 
运行效果以下:
 
 
若是咱们想自定义图片的话,也是很简单的。这时候就不能使用这几个static的函数了,而是要咱们本身定义一个QMessagebox来使用:
 
QMessageBox message(QMessageBox::NoIcon, "Title", "Content with icon.");
message.setIconPixmap(QPixmap( "icon.png"));
message.exec();
 
这里咱们使用的是exec()函数,而不是show(),由于这是一个模态对话框,须要有它本身的事件循环,不然的话,咱们的对话框会一闪而过哦(感谢laetitia提醒).

须要注意的是,同其余的程序相似,咱们在程序中定义的相对路径都是要相对于运行时的.exe文件的地址的。好比咱们写"icon.png",意思是是在.exe的当前目录下寻找一个"icon.png"的文件。这个程序的运行效果以下:
 
 
还有一点要注意,咱们使用的是png格式的图片。由于Qt内置的处理图片格式是png,因此这不会引发很大的麻烦,若是你要使用jpeg格式的图片的话,Qt是以插件的形式支持的。在开发时没有什么问题,不过若是要部署的话,须要注意这一点。
 
最后再来讲一下怎么处理对话框的交互。咱们使用QMessageBox类的时候有两种方式,一是使用static函数,另外是使用构造函数。
 
首先来讲一下static函数的方式。注意,static函数都是要返回一个StandardButton,咱们就能够经过判断这个返回值来对用户的操做作出相应。
 
QMessageBox::StandardButton rb = QMessageBox::question(NULL, "Show Qt", "Do you want to show Qt dialog?", QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes);
if(rb == QMessageBox::Yes)
{
        QMessageBox::aboutQt(NULL, "About Qt");
}
 
若是要使用构造函数的方式,那么咱们就要本身运行判断一下啦:
 
QMessageBox message(QMessageBox::NoIcon, "Show Qt", "Do you want to show Qt dialog?", QMessageBox::Yes | QMessageBox::No, NULL);
if(message.exec() == QMessageBox::Yes)
{
        QMessageBox::aboutQt(NULL, "About Qt");
}
 
其实道理上也是差很少的。
相关文章
相关标签/搜索