2

今天我正在尝试配置一个QTreeView以满足我的要求。我的观点基本上有三列。第二列和第三列应该正好是 50 像素宽,不管小部件的大小是多少。第一列应占据剩余空间。

如果我放大我的小部件,第一列应该自动占据所需的可用空间,而第二列和第三列应该保持它们给定的 50 像素宽度。

这是我到目前为止所尝试的:

主文件

#include <QApplication>
#include <QTreeView>
#include <QDebug>
#include <QStandardItemModel>
#include <QHeaderView>
#include "ColumnDelegate.h"

int main(int argc, char** args) {
    QApplication app(argc, args);
    auto widget = new QTreeView;
    auto model = new QStandardItemModel;
    model->insertRow(0, { new QStandardItem{ "Variable width" }, new QStandardItem{ "Fixed width 1" }, new QStandardItem{ "Fixed width 2" } });
    model->insertRow(0, { new QStandardItem{ "Variable width" }, new QStandardItem{ "Fixed width 1" }, new QStandardItem{ "Fixed width 2" } });
    widget->setModel(model);
    widget->setItemDelegateForColumn(1, new ColumnDelegate);
    widget->setItemDelegateForColumn(2, new ColumnDelegate);
    auto header=widget->header();

    header->setSectionResizeMode(QHeaderView::Fixed);
    header->resizeSection(1, 50);
    header->resizeSection(2, 50);
    widget->show();
    app.exec();
}

列委托.h

#pragma once

#include <QStyledItemDelegate>

class ColumnDelegate : public QStyledItemDelegate {
    Q_OBJECT
public:
    virtual QSize sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const override
    {
        QSize ret= QStyledItemDelegate::sizeHint(option, index);
        ret.setWidth(50);
        return ret;
    }
};

但执行后我得到:

第三列占据了很大的空间

第三列占用更多空间,但第一列应该占用更多空间

有谁知道如何以最少的工作量实现我想要的行为?

4

1 回答 1

8

问题是调整大小模式统一应用于所有部分。您可以使用QHeaderView::setSectionResizeMode允许按部分设置进行细粒度调整的重载。在您的情况下,使用调整大小模式的组合:QHeaderView::Stretch用于扩展列和QHeaderView::Fixed具有固定宽度的列。

此外,您必须禁用自动拉伸最后一部分的设置。使用QHeaderView::setStretchLastSection.

例子:

header->setSectionResizeMode(0, QHeaderView::Stretch);
header->setSectionResizeMode(1, QHeaderView::Fixed);
header->setSectionResizeMode(2, QHeaderView::Fixed);
header->setStretchLastSection(false);

最后,对标有调整大小模式QItemDelegate::sizeHint的部分没有任何影响。QHeaderView::Fixed只需resizeSection使用所需的宽度调用 并忘记项目委托(除非您需要其他任何东西)。

于 2017-12-12T11:58:28.110 回答