Основы программирования в Linux - Мэтью Нейл
0/0

Основы программирования в Linux - Мэтью Нейл

Уважаемые читатели!
Тут можно читать бесплатно Основы программирования в Linux - Мэтью Нейл. Жанр: Интернет. Так же Вы можете читать полную версию (весь текст) онлайн книги без регистрации и SMS на сайте Knigi-online.info (книги онлайн) или прочесть краткое содержание, описание, предисловие (аннотацию) от автора и ознакомиться с отзывами (комментариями) о произведении.
Описание онлайн-книги Основы программирования в Linux - Мэтью Нейл:
В четвертом издании популярного руководства даны основы программирования в операционной системе Linux. Рассмотрены: использование библиотек C/C++ и стан­дартных средств разработки, организация системных вызовов, файловый ввод/вывод, взаимодействие процессов, программирование средствами командной оболочки, создание графических пользовательских интерфейсов с помощью инструментальных средств GTK+ или Qt, применение сокетов и др. Описана компиляция программ, их компоновка c библиотеками и работа с терминальным вводом/выводом. Даны приемы написания приложений в средах GNOME® и KDE®, хранения данных с использованием СУБД MySQL® и отладки программ. Книга хорошо структурирована, что делает обучение легким и быстрым. Для начинающих Linux-программистов
Читем онлайн Основы программирования в Linux - Мэтью Нейл

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать
1 ... 308 309 310 311 312 313 314 315 316 ... 324

delete dialog;

Когда метод exec возвращает управление приложению, диалоговое окно автоматически скрывается, но вы все равно удаляете объект из памяти.

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

Немодальные диалоговые окна

Немодальные диалоговые окна слегка отличаются от обычных основных окон прежде всего тем, что располагаются поверх своего родительского окна, совместно используют их элемент на панели задач и автоматически скрываются, когда вызван слот accept или reject.

Для отображения немодального диалогового окна вызывайте метод 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:

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

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

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

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

 QDialog(parent, name, TRUE) {

 ...

}

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

MySMDialog *dialog = MySMDialog(this, &quot;semimodal&quot;);

dialog-&gt;show();

while (processing) {

 doSomeProcessing();

 app-&gt;processEvents();

 if (dialog-&gt;wasCancelled()) break;

}

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

Комплект Qt предоставляет готовые подклассы класса QDialog, предназначенные для конкретных задач, таких как выбор файлов, ввод текста, индикация процесса выполнения и вывод окна сообщения. Применение этих виджетов в любых приложениях убережет вас от множества неприятностей и проблем.

QMessageBox

QMessageBox — модальное диалоговое окно, отображающее простое сообщение с пиктограммой и кнопками. Пиктограмма зависит от серьезности сообщения, которое может содержать обычные сведения или предупреждения и другую важную информацию.

У класса QMessageBox есть статические методы создания и отображения окон всех трех перечисленных типов:

<b>#include &lt;qmessagebox.h&gt;</b>

<b>int information(QWidget *parent, const QString&amp; caption,</b>

<b> const QString&amp;text, int button0, int button1=0, int button2=0);</b>

<b>int warning(QWidget *parent, const QString&amp; caption,</b>

<b> const QString&amp; text, int button0, int button1, int button2=0);</b>

<b>int critical(QWidget *parent, const QString&amp; caption,</b>

<b> const QString&amp; text, int button0, int button1, int button2=0);</b>

Можно выбрать кнопки из списка готовых кнопок QMessageBox, соответствующих значениям, возвращаемым статическими методами:

□ QMessageBox::Ok;

□ QMessageBox::Cancel;

□ QMessageBox::Yes;

□ QMessageBox::No;

□ QMessageBox::Abort;

□ QMessageBox::Retry;

□ QMessageBox::Ignore.

Типичный пример использования окна QMessageBox будет похож на приведенный далее фрагмент программного кода:

int result = QMessageBox::information(this,

 &quot;Engine Room Query&quot;,

 &quot;Do you wish to engage the HyperDrive?&quot;,

 QMessageBox::Yes | QMessageBox::Default,

 QMessageBox::No | QMessageBox::Escape);

switch (result) {

case QMessageBox::Yes:

 hyperdrive-&gt;engage();

1 ... 308 309 310 311 312 313 314 315 316 ... 324
На этой странице вы можете бесплатно читать книгу Основы программирования в Linux - Мэтью Нейл бесплатно.

Оставить комментарий

Рейтинговые книги