• если пользователь нажимает кнопку OK, мы используем введенные пользователем в диалоговом окне значения соответствующим образом.
Вызов
В объекте
Функция
Более надежным будет такой подход, когда класс
01 void MainWindow::sort
02 {
03 SortDialog dialog(this);
04 QTableWidgetSelectionRange range = spreadsheet->selectedRange;
05 dialog.setColumnRange('A' + range.leftColumn,
06 'А' + range.rightColumn);
07 if (dialog.exec)
08 spreadsheet->performSort(dialog.comparisonObject);
09 }
Такой подход приводит к созданию слабо связанных компонентов, и выбор его почти всегда будет правилен для диалоговых окон, которые вызываются из нескольких мест.
Более «радикальный» подход мог бы заключаться в передаче указателя на объект
01 void MainWindow::sort
02 {
03 SortDialog dialog(this);
04 dialog.setSpreadsheet(spreadsheet);
05 dialog.exec;
06 }
Этот подход является зеркальным отражением первого: вместо знания вызывающим компонентом характерных особенностей диалогового окна теперь само диалоговое окно должно иметь представление об особенностях структур данных, передаваемых вызывающим компонентом. Этот подход полезно применять, когда диалоговому окну требуется отслеживать изменения. В то время как при первом подходе ненадежен код вызвавшего компонента, третий подход перестает работать при изменении структуры данных.
Некоторые разработчики выбирают один из подходов и всегда следуют ему. При этом разработка диалоговых окон становится более привычным и простым делом, однако достоинства других подходов не будут использованы. В идеале решение по выбору конкретного подхода должно учитывать в каждом случае особенности конкретного диалогового окна.
Мы завершим данный раздел созданием диалогового окна About (справка о программе). Мы могли бы создать для представления данных о программе специальное диалоговое окно наподобие созданных нами ранее Find или Go-to-Cell, но поскольку диалоговые окна About сильно стилизованы, в средствах разработки Qt предусмотрено простое решение:
01 void MainWindow::about
02 {
03 QMessageBox::about(this, tr("About Spreadsheet"),