网站首页 > 基础教程 正文
对话框在Qt GUI应用程序中有着广泛的用途,对话框有模态、非模态两种情况。
对于参数选择的对话框,一般用模态对话框;对于显示或查看某些内容的对话框,一般用非模态对话框。
对话框类QDialog,官方文档:http://qt-project.org/doc/qt-4.8/qdialog.html
1. 模态对话框
模态对话框通过调用exec()函数实现,使用模态对话框时,事件就在对话框内部循环,必须将对话框关闭才能继续执行主界面的操作。
需要注意的是,关闭模态对话框时,exec()将返回一个值。
原型:int QDialog::exec () [slot]
返回值利用:比如对话框中有Ok和Cancel两个按钮,点击Ok按钮时,关闭对话框同时主程序接受对话框中设置的参数,点击Cancel或右上角的X后,关闭对话框并且立即返回不再执行下面的程序。这种情况下,将Ok按钮的clicked()信号与accept()槽连接,Cancel按钮的clicked信号与reject()槽连接。这时,当点击Ok按钮时,将触发accept()槽,exec()返回QDialog::Recepted,当点击Cancel按钮时,将触发reject槽,exec()返回QDialog::Rejected。
connect(ui.Ok,SIGNAL(clicked()),this,SLOT(accept()));
connect(ui.Cancel,SIGNAL(clicked()),this,SLOT(reject()));
执行时,进行一下判断,点击了Cancel返回,点击了Ok传递对话框中的参数继续执行
//在某个函数中调用对话框
// a为对话框类对象
if(a.exec() == QDialog::Rejected)
{
//操作
return;
}
//传递对话框中的参数
//继续操作
不知道说明白了没有,不明白的话自己下代码实现一下。
2. 非模态对话框
非模态对话框调用show()函数实现,当然在主程序中,调用非模态对话框时,如果只写个show(),可能是对话框一闪而过,为了解决这个情况,需要全局对象的事件响应槽processEvents(),定时的访问该对话框,这样就可以处理主界面的事件同时对话框也不会消失。
本人采用方法时利用QTimer类的singleShot()方法。QTimer类提供了对时钟的操作。
QTimer类的官方文档:http://qt-project.org/doc/qt-4.8/qtimer.html
singleShot的原型:void QTimer::singleShot ( int msec, QObject * receiver, const char * member ) [static]
第一个参数为执行的时间间隔,单位为ms
第二个参数为接受的对象
第三个参数为触发的槽
恰好,我们可以每隔msec时间触发processEvents(),从而使对话框不消失,第二个参数为对话框对象。需要注意的是,对话框的对象要定义在堆上(即要定义成指针对象),因为如果定义在栈上,执行完后函数后对象会被自动清理掉,找不到第二个参数所需的对象,就没法显示出对话框了。
#include <QTimer>
CModallessDialog *dialog; //最好定义成全局变量
dialog = new CModallessDialog;
dialog->show();
dialog->setTitle(tr("非模态对话框")); //设置窗口标题
//对话框中的一些处理
QTimer::singleShot(200,dialog,SLOT(qApp->processEvents())); //时间间隔200ms
在使用时,将dialog对象delete掉之后对话框就会消失
//如果对话框显示,就将其删除
if(NULL!=dialog)
{
delete dialog
dialog=NULL;
}
在显示对话框时,也要注意如果dialog!=NULLs时,现将其delete掉赋NULL再分配地址。
猜你喜欢
- 2024-10-29 将vue代码改写成react vue文件如何编译成html
- 2024-10-29 CKEditor 4.14:支持复制粘贴 LibreOffice 文档的富文本编辑器
- 2024-10-29 Vuejs通过浏览器导航关闭模态框,实现增强的用户体验
- 2024-10-29 jQuery UI 小部件(Widget)方法调用
- 2024-10-29 HTML5新增元素介绍及运用 html5新增的功能元素
- 2024-10-29 HTML 打印问题汇总 html怎么打印
- 2024-10-29 HTML 语法的变化,HTML5有哪些新的元素和属性
- 2024-10-29 Element Plus 的 Dialog 组件实现点击遮罩层不关闭对话框
- 2024-10-29 WebView与JavaScript的交互 webview与js交互原理
- 2024-10-29 1-html基本知识 html的基本内容
- 最近发表
- 标签列表
-
- jsp (69)
- pythonlist (60)
- gitpush (78)
- gitreset (66)
- python字典 (67)
- dockercp (63)
- gitclone命令 (63)
- dockersave (62)
- linux命令大全 (65)
- pythonif (68)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- console.table (62)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)