Для отображения немодального диалогового окна вызывайте метод
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,
const QString& text, int button0, int button1, int button2=0);
int critical(QWidget *parent, const QString& caption,
const QString& text, int button0, int button1, int button2=0);
Можно выбрать кнопки из списка готовых кнопок
QMessageBox
, соответствующих значениям, возвращаемым статическими методами:
QMessageBox::Ok
;
QMessageBox::Cancel
;
QMessageBox::Yes
;
QMessageBox::No
;
QMessageBox::Abort
;
QMessageBox::Retry
;
QMessageBox::Ignore
.
Типичный пример использования окна
QMessageBox
будет похож на приведенный далее фрагмент программного кода:
int result = QMessageBox::information(this,
"Engine Room Query",
"Do you wish to engage the HyperDrive?",
QMessageBox::Yes | QMessageBox::Default,
QMessageBox::No | QMessageBox::Escape);
switch (result) {
case QMessageBox::Yes:
hyperdrive->engage;
break;
case QMessageBox::No:
// сделайте что-нибудь еще
break;
}
Вы соединили операцией
OR
(
|
) коды кнопок с вариантами
Default
и
Escape
, чтобы задать стандартные действия, при нажатии клавиш <Enter> (или <Return>) и <Esc>. Результирующее диалоговое окно показано на рис. 17.8.
Рис. 17.8
QInputDialog
Окно
QInputDialog
полезно для ввода пользователем отдельных значений, будь то текст, вариант раскрывающегося списка, целочисленное или действительное значение. У класса
QInputDialog
есть статические методы, например
QMessageBox
, создающие некоторые проблемы, поскольку у них слишком много параметров, к счастью, у большинства из них есть значения по умолчанию: