, которые применяются для обозначения результата, полученного в диалоговом окне. Этот результат возвращается методом exec. Как правило, вы будете связывать кнопки OK и Cancel со слотами, как в
MyDialog
.
Модальные диалоговые окна
Для применения диалогового окна как модального вы вызываете метод
exec
, который открывает диалоговое окно и возвращает
QDialog::Accepted
или
QDialog::Rejected
в зависимости от того, какой слот был активизирован:
MyDialog* dialog = new MyDialog(this, "mydialog");
if (dialog->exec == QDialog::Accepted) {
// Пользователь щелкнул мышью кнопку OK
doSomething;
} else {
// Пользователь щелкнул мышью кнопку Cancel или
// диалоговое окно уничтожено
doSomethingElse;
}
delete dialog;
Когда метод
exec
возвращает управление приложению, диалоговое окно автоматически скрывается, но вы все равно удаляете объект из памяти.
Учтите, что когда вызывается
exec
, вся обработка прекращается, поэтому, если в вашем приложении есть важный с точки зрения затраченного времени программный код, больше подойдут немодальное или полумодальное диалоговые окна.
Немодальные диалоговые окна
Немодальные диалоговые окна слегка отличаются от обычных основных окон прежде всего тем, что располагаются поверх своего родительского окна, совместно используют их элемент на панели задач и автоматически скрываются, когда вызван слот
accept
или
reject
.
Для отображения немодального диалогового окна вызывайте метод
show
, как вы сделали бы для окна
QMainWindow
:
MyDialog *dialog = new MyDialog(this, "mydialog");
dialog->show;
Функция
show
выводит диалоговое окно на экран и немедленно возвращается в приложение для продолжения цикла выполнения. Для обработки нажатой кнопки вы должны написать слоты и установить с ними связь:
Перед продолжением выполнения проверьте, не уничтожено ли диалоговое окно. Имейте в виду, что функция
wasCancelled
не является частью класса
QDialog
— вы должны написать ее самостоятельно.
Комплект Qt предоставляет готовые подклассы класса
QDialog
, предназначенные для конкретных задач, таких как выбор файлов, ввод текста, индикация процесса выполнения и вывод окна сообщения. Применение этих виджетов в любых приложениях убережет вас от множества неприятностей и проблем.
QMessageBox
QMessageBox
— модальное диалоговое окно, отображающее простое сообщение с пиктограммой и кнопками. Пиктограмма зависит от серьезности сообщения, которое может содержать обычные сведения или предупреждения и другую важную информацию.
У класса
QMessageBox
есть статические методы создания и отображения окон всех трех перечисленных типов:
#include <qmessagebox.h>
int information(QWidget *parent, const QString& caption,
const QString&text, int button0, int button1=0, int button2=0);
int warning(QWidget *parent, const QString& caption,