Красными линиями на форме обозначаются созданные менеджеры компоновки. Они невидимы при выполнении программы.
Рис. 2.8. Форма с менеджерами компоновки.
Теперь выберите в меню функцию Edit | Edit Tab Order (Правка | Редактировать порядок перехода по клавише табуляции). Рядом с каждым виджетом, которому может передаваться фокус, появятся синие прямоугольники. Щелкните по каждому виджету, соблюдая необходимую вам последовательность перевода фокуса, затем выберите в меню функцию Edit | Edit Widgets для выхода из режима редактирования переходов по клавише табуляции.
Рис. 2.9. Установка последовательности перевода фокуса по виджетам формы.
Для предварительного просмотра спроектированного диалогового окна выберите в меню функцию Form | Preview (Форма | Предварительный просмотр). Проверьте последовательность перехода фокуса, нажимая несколько раз клавишу табуляции. Нажмите одновременно клавиши Alt+C для перевода фокуса на строку редактирования. Нажмите на кнопку Cancel для прекращения работы.
Сохраните спроектированное диалоговое окно в файле gotocelldialog.ui в каталоге с названием gotocell и создайте файл main.cpp в том же каталоге с помощью обычного текстового редактора.
01 #include <QApplication>
02 #include <QDialog>
03 #include "ui_gotocelldialog.h"
04 int main(int argc, char *argv[])
05 {
06 QApplication app(argc, argv);
07 Ui::GoToCellDialog ui;
08 QDialog *dialog = new QDialog;
09 ui.setupUi(dialog);
10 dialog->show();
11 return app.exec();
12 }
Теперь выполните команду qmake для создания файла с расширением .pro и затем создайте файл makefile (команды qmake —project; qmake gotocell.pro). Программе qmake «хватит ума» обнаружить файл пользовательского интерфейса gotocelldialog.ui и сгенерировать соответствующие команды для вызова uic — компилятора пользовательского интерфейса, входящего в состав средств разработки Qt. Компилятор uic преобразует gotocelldialog.ui в инструкции С++ и помещает результат в ui_gotocelldialog.h.
Полученный файл ui_gotocelldialog.h содержит определение класса Ui::GoToCellDialog, который содержит инструкции С++, эквивалентные файлу gotocelldialog.ui. В этом классе объявляются переменные—члены, в которых содержатся дочерние виджеты и менеджеры компоновки формы, а также функция setupUi(), которая инициализирует форму. Сгенерированный класс выглядит следующим образом:
class Ui::GoToCellDialog
{
public:
QLabel *label;
QLineEdit *lineEdit;
QSpacerItem *spacerItem;
QPushButton *okButton;
QPushButton *cancelButton;
…
void setupUi(QWidget *widget) {
…
}
};
Сгенерированный класс не наследует никакой Qt—класс. При использовании формы в main.cpp мы создаем QDialog и передаем его функции setupUi().
Если вы станете выполнять программу в данный момент, она будет работать, но не совсем так, как требуется:
• кнопка OK всегда будет в неактивном состоянии;
• кнопка Cancel не выполняет никаких действий;
• поле редактирования будет принимать любой текст, а оно должно принимать только допустимое обозначение ячейки.
Правильную работу диалогового окна мы можем обеспечить, написав некоторый программный код. Лучше всего создать новый класс, который наследует QDialog и Ui::GoToCellDialog и реализует недостающую функциональность (подтверждая известное утверждение, что любую проблему программного обеспечения можно решить, просто добавив еще один уровень представления объектов). По нашим правилам мы даем этому новому классу такое же имя, которое генерируется компилятором uic, но без префикса Ui::.
Используя текстовый редактор, создайте файл с именем gotocelldialog.h, который будет содержать следующий код:
01 #ifndef GOTOCELLDIALOG_H
02 #define GOTOCELLDIALOG_H
03 #include <QDialog>
04 #include "ui_gotocelldialog.h"
05 class GoToCellDialog : public QDialog, public Ui::GoToCellDialog
06 {
07 Q_OBJECT
08 public:
09 GoToCellDialog(QWidget *parent = 0);
10 private slots:
11 void on_lineEdit_textChanged();
12 };
13 #endif
Реализация методов класса делается в файле gotocelldialog.cpp:
01 #include <QtGui>
02 #include "gotocelldialog.h"