Пример "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);
};
Реализация класса PermissionsTab
PermissionsTab показывает информацию о доступе к файлу, выводя на экран детали прав доступа к файлу и владельца в виджетах, которые расположенные во вложенных компоновках:
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);
}
Определение класса ApplicationsTab
ApplicationsTab - другой виджет-заполнитель, который главным образом косметический:
class ApplicationsTab : public QWidget
{
Q_OBJECT
public:
ApplicationsTab(const QFileInfo &fileInfo, QWidget *parent = 0);
};
Реализация класса ApplicationsTab
ApplicationsTab не показывает какую-либо полезную информацию, но может быть использована как шаблон для более сложного примера:
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);
}
|