1.QDialog是Qt中所有对话框窗口的基类,继承与QWidget是一种容器类型的组件
QDialog的意义:
- QDialog作为一种专用的交互窗口而存在
- QDialog不能作为子部件嵌入其他容器中
- QDialog是定制了窗口式样的特殊的QWidget
QDialog只能位于最顶层,没有最大化最小化功能
#include "Dialog.h"
#include <QApplication>
#include <QDialog>
#include <QWidget>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QWidget widget;
QDialog dialog(&widget);
dialog.show();
dialog.setWindowTitle("dialog");
widget.show();
widget.setWindowTitle("widget");
return QCoreApplication::exec();
}
运行结果:

2.对话框类型
(1)模态对话框
- 显示后无法与父窗口进行交互
- 是一种阻塞式的对话框调用方式
- 例如关闭记事本后弹出的是否保存的对话框
(2)非模态对话框
- 显示后独立存在可以同时与父窗口进行交互
- 是一种非阻塞式的对话框调用方式
- 例如查找弹窗
注意:
- 在栈上创建模态对话框是最简单常用的方式
- 一般情况下非模态对话框需要在堆上创建
- 通过QDialog::setModal函数可以创建混合特性的对话框
- 非模态对话框需要指定Qt::WA_DeleteOnClose属性
Dialog.h
#ifndef DIALOG_H
#define DIALOG_H
#include <QMainWindow>
#include <QPushButton>
#include <QDialog>
class Dialog : public QDialog
{
Q_OBJECT
protected:
QPushButton ModalBtn;
QPushButton NormalBtn;
QPushButton MixedBtn;
protected slots:
void ModalBtn_Clicked();
void NormalBtn_Clicked();
void MixedBtn_Clicked();
public:
Dialog(QWidget *parent = 0); //parent = 0:父窗口指针,默认值为 0(表示无父窗口,顶层对话框)
~Dialog();
};
#endif //DIALOG_H
Dialog.cpp
#include "Dialog.h"
#include "ui_dialog.h"
#include <QDebug>
Dialog::Dialog(QWidget *parent)
: QDialog(parent), ModalBtn(this), NormalBtn(this), MixedBtn(this)
{
ModalBtn.setText("Modal Dialog");
ModalBtn.move(20, 20);
ModalBtn.resize(100, 30);
NormalBtn.setText("Normal Dialog");
NormalBtn.move(20, 70);
NormalBtn.resize(100, 30);
MixedBtn.setText("Mixed Dialog");
MixedBtn.move(20, 120);
MixedBtn.resize(100, 30);
//this 在这里指代当前 Dialog 类的对象本身
connect(&ModalBtn, SIGNAL(clicked()), this, SLOT(ModalBtn_Clicked()));
connect(&NormalBtn, SIGNAL(clicked()), this, SLOT(NormalBtn_Clicked()));
connect(&MixedBtn, SIGNAL(clicked()), this, SLOT(MixedBtn_Clicked()));
resize(140, 170);
}
void Dialog::ModalBtn_Clicked()
{
qDebug() << "ModalBtn_Clicked() Begin";
QDialog dialog(this); //把父窗口设为当前窗口
dialog.exec();
qDebug() << "ModalBtn_Clicked() End";
}
void Dialog::NormalBtn_Clicked()
{
qDebug() << "NormalBtn_Clicked() Begin";
QDialog* dialog = new QDialog(this); //必须用 new,否则函数结束对话框会消失
dialog->setAttribute(Qt::WA_DeleteOnClose ); //关闭对话框时,自动释放内存,否则会内存泄漏
dialog->show();
qDebug() << "NormalBtn_Clicked() End";
}
void Dialog::MixedBtn_Clicked() //混合对话框
{
qDebug() << "MixedBtn_Clicked() Begin";
QDialog* dialog = new QDialog(this);
dialog->setAttribute(Qt::WA_DeleteOnClose);
dialog->setModal(this);
dialog->show();
qDebug() << "MixedBtn_Clicked() End";
}
Dialog::~Dialog()
{
qDebug() << "~Dialog()";
}
3.对话框的返回值
(1)只有模态对话框才有返回值的概念
(2)模态对话框的返回值用于表示交互结果
(3)QDialog::exec()的返回值为交互结果
- void QDialog::done(int i) 关闭对话框并将参数作为交互结果
- QDialog::Accepted------用户操作成功
- QDialog::Rejected------用户操作失败
Dialog.cpp
#include "Dialog.h"
#include "ui_dialog.h"
#include <QDebug>
Dialog::Dialog(QWidget *parent)
: QDialog(parent), ModalBtn(this), NormalBtn(this), MixedBtn(this)
{
ModalBtn.setText("Modal Dialog");
ModalBtn.move(20, 20);
ModalBtn.resize(100, 30);
NormalBtn.setText("Normal Dialog");
NormalBtn.move(20, 70);
NormalBtn.resize(100, 30);
MixedBtn.setText("Mixed Dialog");
MixedBtn.move(20, 120);
MixedBtn.resize(100, 30);
//this 在这里指代当前 Dialog 类的对象本身
connect(&ModalBtn, SIGNAL(clicked()), this, SLOT(ModalBtn_Clicked()));
connect(&NormalBtn, SIGNAL(clicked()), this, SLOT(NormalBtn_Clicked()));
connect(&MixedBtn, SIGNAL(clicked()), this, SLOT(MixedBtn_Clicked()));
resize(140, 170);
}
void Dialog::ModalBtn_Clicked()
{
qDebug() << "ModalBtn_Clicked() Begin";
// QDialog dialog(this); //把父窗口设为当前窗口
// dialog.exec();
done(Accepted);
qDebug() << "ModalBtn_Clicked() End";
}
void Dialog::NormalBtn_Clicked()
{
qDebug() << "NormalBtn_Clicked() Begin";
// QDialog* dialog = new QDialog(this); //必须用 new,否则函数结束对话框会消失
// dialog->setAttribute(Qt::WA_DeleteOnClose ); //关闭对话框时,自动释放内存,否则会内存泄漏
// dialog->show();
done(Rejected);
qDebug() << "NormalBtn_Clicked() End";
}
void Dialog::MixedBtn_Clicked() //混合对话框
{
qDebug() << "MixedBtn_Clicked() Begin";
// QDialog* dialog = new QDialog(this);
// dialog->setAttribute(Qt::WA_DeleteOnClose);
// dialog->setModal(this);
// dialog->show();
done(100);
qDebug() << "MixedBtn_Clicked() End";
}
Dialog::~Dialog()
{
qDebug() << "~Dialog()";
}
main.cpp
#include "Dialog.h"
#include <QDebug>
#include <QApplication>
#include <QDialog>
#include <QWidget>
int main(int argc, char *argv[])
{
QApplication a(argc, argv);
Dialog dig;
int r = dig.exec();
if( r == QDialog::Accepted )
{
qDebug() << "Accepted";
}
else if( r == QDialog::Rejected )
{
qDebug() << "Rejected";
}
else
{
qDebug() << r;
}
dig.show();
return r;
}