Пример "Tab Dialog"
Файлы: Пример "Tab Dialog" показывает, как создавать диалог со вкладками используя класс QTabWidget. Диалоги предоставляют приложению эффективный способ взаимодействовать с пользователем, но сложные диалоги страдают проблемой, что они часто занимают слишком большую площадь экрана. Используя в диалоге несколько вкладок информация может быть разделена на различные категории, остающуюся доступной. Пример "Tab Dialog" состоит из одного класса TabDialog, который предоставляет три вкладки, каждая содержит информацию об отдельном файле, и две стандартных кнопки, которые используются для принятия или отклонения содержимого диалога. Определение класса TabDialogКласс TabDialog - подкласс QDialog, который отображает QTabWidget и две стандартные кнопки диалога. Определение класса содержит только конструктор класса и закрытый член данных для QTabWidget: class TabDialog : public QDialog { Q_OBJECT public: TabDialog(const QString &fileName, QWidget *parent = 0); private: QTabWidget *tabWidget; QDialogButtonBox *buttonBox; }; В примере виджет будет использоваться как окно верхнего уровня, но мы определили конструктор так, что он может принять родительский виджет. Это позволяет диалогу быть центрированным в верхней части главного окна приложения. Реализация класса TabDialogКонструктор вызывает конструктор QDialog создаёт объект QFileInfo для заданного имени файла. TabDialog::TabDialog(const QString &fileName, QWidget *parent) : QDialog(parent) { QFileInfo fileInfo(fileName); tabWidget = new QTabWidget; tabWidget->addTab(new GeneralTab(fileInfo), tr("General")); tabWidget->addTab(new PermissionsTab(fileInfo), tr("Permissions")); tabWidget->addTab(new ApplicationsTab(fileInfo), tr("Applications")); Виджет со вкладками заполняется тремя пользовательскими виджетами, каждый из которых содержит информацию о файле. Мы создаём каждый из этих виджетов без родителя, поскольку виджет со вкладками перепривязать их родителя так как они были добавлены к нему. Мы создаём две стандартных кнопки и соединяем каждый из них с соответствующими слотами диалога: buttonBox = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel); connect(buttonBox, SIGNAL(accepted()), this, SLOT(accept())); connect(buttonBox, SIGNAL(rejected()), this, SLOT(reject())); Расставляем виджет со вкладками вокруг кнопок диалога: QVBoxLayout *mainLayout = new QVBoxLayout; mainLayout->addWidget(tabWidget); mainLayout->addWidget(buttonBox); setLayout(mainLayout); В завершение устанавливаем заголовок диалога: setWindowTitle(tr("Tab Dialog")); } Каждая из вкладок унаследована от QWidget, и предоставляет только конструкторы. Определение класса GeneralTabОпределение виджета GeneralTab простое, поскольку мы интересуемся выводом на экран содержимого виджета внутри вкладки: class GeneralTab : public QWidget { Q_OBJECT public: GeneralTab(const QFileInfo &fileInfo, QWidget *parent = 0); }; Реализация класса GeneralTabВиджет GeneralTab просто выводит на экран некоторую информацию о файле, переданном из TabDialog. Виджеты для этой цели разные и расположены они внутри вертикальной компоновки: GeneralTab::GeneralTab(const QFileInfo &fileInfo, QWidget *parent) : QWidget(parent) { QLabel *fileNameLabel = new QLabel(tr("File Name:")); QLineEdit *fileNameEdit = new QLineEdit(fileInfo.fileName()); QLabel *pathLabel = new QLabel(tr("Path:")); QLabel *pathValueLabel = new QLabel(fileInfo.absoluteFilePath()); pathValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QLabel *sizeLabel = new QLabel(tr("Size:")); qlonglong size = fileInfo.size()/1024; QLabel *sizeValueLabel = new QLabel(tr("%1 K").arg(size)); sizeValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QLabel *lastReadLabel = new QLabel(tr("Last Read:")); QLabel *lastReadValueLabel = new QLabel(fileInfo.lastRead().toString()); lastReadValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QLabel *lastModLabel = new QLabel(tr("Last Modified:")); QLabel *lastModValueLabel = new QLabel(fileInfo.lastModified().toString()); lastModValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QVBoxLayout *mainLayout = new QVBoxLayout; mainLayout->addWidget(fileNameLabel); mainLayout->addWidget(fileNameEdit); mainLayout->addWidget(pathLabel); mainLayout->addWidget(pathValueLabel); mainLayout->addWidget(sizeLabel); mainLayout->addWidget(sizeValueLabel); mainLayout->addWidget(lastReadLabel); mainLayout->addWidget(lastReadValueLabel); mainLayout->addWidget(lastModLabel); mainLayout->addWidget(lastModValueLabel); mainLayout->addStretch(1); setLayout(mainLayout); } Определение класса PermissionsTabКак и GeneralTab, PermissionsTab используется только как виджет-заполнитель для его потомков: class PermissionsTab : public QWidget { Q_OBJECT public: PermissionsTab(const QFileInfo &fileInfo, QWidget *parent = 0); }; Реализация класса PermissionsTabPermissionsTab показывает информацию о доступе к файлу, выводя на экран детали прав доступа к файлу и владельца в виджетах, которые расположенные во вложенных компоновках: PermissionsTab::PermissionsTab(const QFileInfo &fileInfo, QWidget *parent) : QWidget(parent) { QGroupBox *permissionsGroup = new QGroupBox(tr("Permissions")); QCheckBox *readable = new QCheckBox(tr("Readable")); if (fileInfo.isReadable()) readable->setChecked(true); QCheckBox *writable = new QCheckBox(tr("Writable")); if ( fileInfo.isWritable() ) writable->setChecked(true); QCheckBox *executable = new QCheckBox(tr("Executable")); if ( fileInfo.isExecutable() ) executable->setChecked(true); QGroupBox *ownerGroup = new QGroupBox(tr("Ownership")); QLabel *ownerLabel = new QLabel(tr("Owner")); QLabel *ownerValueLabel = new QLabel(fileInfo.owner()); ownerValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QLabel *groupLabel = new QLabel(tr("Group")); QLabel *groupValueLabel = new QLabel(fileInfo.group()); groupValueLabel->setFrameStyle(QFrame::Panel | QFrame::Sunken); QVBoxLayout *permissionsLayout = new QVBoxLayout; permissionsLayout->addWidget(readable); permissionsLayout->addWidget(writable); permissionsLayout->addWidget(executable); permissionsGroup->setLayout(permissionsLayout); QVBoxLayout *ownerLayout = new QVBoxLayout; ownerLayout->addWidget(ownerLabel); ownerLayout->addWidget(ownerValueLabel); ownerLayout->addWidget(groupLabel); ownerLayout->addWidget(groupValueLabel); ownerGroup->setLayout(ownerLayout); QVBoxLayout *mainLayout = new QVBoxLayout; mainLayout->addWidget(permissionsGroup); mainLayout->addWidget(ownerGroup); mainLayout->addStretch(1); setLayout(mainLayout); } Определение класса ApplicationsTabApplicationsTab - другой виджет-заполнитель, который главным образом косметический: class ApplicationsTab : public QWidget { Q_OBJECT public: ApplicationsTab(const QFileInfo &fileInfo, QWidget *parent = 0); }; Реализация класса ApplicationsTabApplicationsTab не показывает какую-либо полезную информацию, но может быть использована как шаблон для более сложного примера: ApplicationsTab::ApplicationsTab(const QFileInfo &fileInfo, QWidget *parent) : QWidget(parent) { QLabel *topLabel = new QLabel(tr("Open with:")); QListWidget *applicationsListBox = new QListWidget; QStringList applications; for (int i = 1; i <= 30; ++i) applications.append(tr("Application %1").arg(i)); applicationsListBox->insertItems(0, applications); QCheckBox *alwaysCheckBox; if (fileInfo.suffix().isEmpty()) alwaysCheckBox = new QCheckBox(tr("Always use this application to " "open this type of file")); else alwaysCheckBox = new QCheckBox(tr("Always use this application to " "open files with the extension '%1'").arg(fileInfo.suffix())); QVBoxLayout *layout = new QVBoxLayout; layout->addWidget(topLabel); layout->addWidget(applicationsListBox); layout->addWidget(alwaysCheckBox); setLayout(layout); }
|
Попытка перевода Qt документации. Если есть желание присоединиться, или если есть замечания или пожелания, то заходите на форум: Перевод Qt документации на русский язык... Люди внесшие вклад в перевод: Команда переводчиков |