Чтение онлайн

ЖАНРЫ

Основы программирования в Linux
Шрифт:

Для отображения немодального диалогового окна вызывайте метод

show
, как вы сделали бы для окна
QMainWindow
:

MyDialog *dialog = new MyDialog(this, "mydialog");

dialog->show;

Функция

show
выводит диалоговое окно на экран и немедленно возвращается в приложение для продолжения цикла выполнения. Для обработки нажатой кнопки вы должны написать слоты и установить с ними связь:

MyDialog::MyDialog(QWidget *parent, const char *name) :

 QDialog(parent, name) {

 ...

 connect(ok_pushbutton, SIGNAL(clicked), this, SLOT(OkClicked));

 connect(cancel_pushbutton, SIGNAL(clicked), this, SLOT(CancelClicked));

}

MyDialog::OkClicked {

 //
Выполните что-либо

}

MyDialog::CancelClicked {

 // Выполните что-либо другое

}

Как и в случае модального окна, диалоговое окно автоматически скрывается при нажатии кнопки.

Полумодальное диалоговое окно

Для создания полумодального диалогового окна вы должны задать флаг модального режима в конструкторе

QDialog
и применить метод
show
:

QDialog(QWidget *parent=0, const char *name=0, bool modal=FALSE, WFlags f=0);

Вы не задаете в модальном диалоговом окне флаг модального режима равным

TRUE
, потому что вызов
exec
заставляет диалоговое окно перейти в модальный режим независимо от значения этого флага.

Конструктор вашего диалогового окна будет выглядеть примерно следующим образом:

MySMDialog::MySMDialog(QWidget *parent, const char *name):

 QDialog(parent, name, TRUE) {

 ...

}

После того как вы определили ваше диалоговое окно, вызовите функцию

show
как обычно и затем продолжите свою обработку, периодически вызывая
QApplication::processEvents
для обновления вашего диалогового окна:

MySMDialog *dialog = MySMDialog(this, "semimodal");

dialog->show;

while (processing) {

 doSomeProcessing;

 app->processEvents;

 if (dialog->wasCancelled) break;

}

Перед продолжением выполнения проверьте, не уничтожено ли диалоговое окно. Имейте в виду, что функция

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
, создающие некоторые проблемы, поскольку у них слишком много параметров, к счастью, у большинства из них есть значения по умолчанию:

Поделиться с друзьями: