Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/qt/7.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PyQt:如何设置QTreeView的行高_Qt_Pyqt_Pyside_Pyqt5_Qtreeview - Fatal编程技术网

PyQt:如何设置QTreeView的行高

PyQt:如何设置QTreeView的行高,qt,pyqt,pyside,pyqt5,qtreeview,Qt,Pyqt,Pyside,Pyqt5,Qtreeview,在PyQt中,我正在寻找一种方法来设置QTreeView中的行高度(类似于QTableView.setRowHeight(row,row_height),但是QTreeView没有此功能)qabstractemmodel用于设置树模型。我阅读了一些使用和子分类qabstractemdelegate.sizeHint(选项,索引)的建议,但我不知道如何在树模型中正确调用它们 任何最低限度的代码或建议将不胜感激。谢谢。 不知道Python,但是C++代码会是这样的: model->setDat

在PyQt中,我正在寻找一种方法来设置
QTreeView
中的行高度(类似于
QTableView.setRowHeight(row,row_height)
,但是
QTreeView
没有此功能)
qabstractemmodel
用于设置树模型。我阅读了一些使用和子分类
qabstractemdelegate.sizeHint(选项,索引)
的建议,但我不知道如何在树模型中正确调用它们


任何最低限度的代码或建议将不胜感激。谢谢。

不知道Python,但是C++代码会是这样的:

model->setData(model->index(/*your index*/), QSize(20, 20), Qt::SizeHintRole);
def data(self, index, role = QtCore.Qt.DisplayRole):
    #  Check the index, possibly return None
    if role == QtCore.Qt.DisplayRole:
        # Return the data
    elif role == QtCore.Qt.SizeHintRole:
        return QtCore.QSize(item_width,item_height)
    # Other roles - maybe return None if you don't use them.
您需要为树中的所有项目设置它

如果您想使用QItemDelegate-您无需调用此函数,只需将委托设置为view,如下所示(再次使用C++代码,但主要思想相同):


视图将在需要时使用它。

QTreeView根据为每个项目返回的数据和大小提示计算出每行的高度。我认为您可能只需要返回所有项目的大小提示,或者至少返回第一行(如果您有
setUniformRowHeights(True)
)。顺便说一句,这可以显著提高性能,因此如果可以,您应该设置它

因此,您只需实现
AbstractItemModel.data()
方法,即可在
SizeIntrole
中返回大小提示。大概是这样的:

model->setData(model->index(/*your index*/), QSize(20, 20), Qt::SizeHintRole);
def data(self, index, role = QtCore.Qt.DisplayRole):
    #  Check the index, possibly return None
    if role == QtCore.Qt.DisplayRole:
        # Return the data
    elif role == QtCore.Qt.SizeHintRole:
        return QtCore.QSize(item_width,item_height)
    # Other roles - maybe return None if you don't use them.
编辑:大示例

您说您仍然有问题,因此这里有一个完整的工作示例,基于标准的QT ItemView示例。尝试更改data方法中返回的QSize以查看视图如何更改:

import sys
from PySide import QtCore,QtGui

class TreeItem(object):
    def __init__(self, data, parent=None):
        self.parentItem = parent
        self.data = data
        self.childItems = []

    def appendChild(self, item):
        self.childItems.append(item)

    def row(self):
        if self.parentItem:
            return self.parentItem.childItems.index(self)
        return 0


class TreeModel(QtCore.QAbstractItemModel):
    def __init__(self, parent=None):
        super(TreeModel, self).__init__(parent)
        self.rootItem = TreeItem(None)
        for i,c in enumerate("abcdefg"):
            child = TreeItem([i,c],self.rootItem)
            self.rootItem.appendChild(child)
        parent = self.rootItem.childItems[1]
        child = TreeItem(["down","down"],parent)
        parent.appendChild(child)

    def columnCount(self, parent):
        return 2

    def data(self, index, role):
        if not index.isValid():
            return None
        if role == QtCore.Qt.DisplayRole:
            item = index.internalPointer()
            return item.data[index.column()]
        elif role == QtCore.Qt.SizeHintRole:
            print "giving size hint"
            return QtCore.QSize(40,40)

        return None


    def flags(self, index):
        if not index.isValid():
            return QtCore.Qt.NoItemFlags
        return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable

    def headerData(self, section, orientation, role):
        if orientation == QtCore.Qt.Horizontal and role == QtCore.Qt.DisplayRole:
            return ["A","B"][section]
        return None

    def index(self, row, column, parent):
        if not self.hasIndex(row, column, parent):
            return QtCore.QModelIndex()

        if not parent.isValid():
            parentItem = self.rootItem
        else:
            parentItem = parent.internalPointer()

        childItem = parentItem.childItems[row]
        if childItem:
            return self.createIndex(row, column, childItem)
        else:
            return QtCore.QModelIndex()

    def parent(self, index):
        if not index.isValid():
            return QtCore.QModelIndex()
        parentItem = index.internalPointer().parentItem
        if parentItem == self.rootItem:
            return QtCore.QModelIndex()
        return self.createIndex(parentItem.row(), 0, parentItem)

    def rowCount(self, parent):
        if parent.column() > 0:
            return 0
        if not parent.isValid():
            parentItem = self.rootItem
        else:
            parentItem = parent.internalPointer()
        return len(parentItem.childItems)



if __name__ == '__main__':

    app = QtGui.QApplication(sys.argv)
    model = TreeModel()

    view = QtGui.QTreeView()
    view.setModel(model)
    view.setWindowTitle("Simple Tree Model")
    view.show()
    sys.exit(app.exec_())

对于PySide绑定,下面是AbstractItemModel上自定义委托的Python代码

from PySide import QtCore, QtGui

tree = QTreeView()
tree.model = QtGui.QAbstractItemModel()
tree.setModel(tree.model)

size = QtCore.QSize(20, 20)
index = tree.model.index(row, col)   # row, col are your own
tree.model.setData(index, size, QtCore.Qt.SizeHintRole)

delegate = MyDelegate()
tree.setItemDelegate(delegate)

这只是将代码从@RazrFalcon翻译成Python,是另一个用户请求的。

使用样式表执行此操作非常简单:

self.setStyleSheet("QTreeView::item { padding: 10px }")

在Qt5.9.2中,我无法同时获得QTreeView自动调整列大小和自定义行高度。使用SizeHintRole对高度有效,但似乎破坏了自动宽度。我的解决方案是将行设置为具有统一的高度,然后在Python 3.7中执行类似的操作:

self._tree = QTreeView()
self._tree.setAlternatingRowColors(True)
self._tree.setUniformRowHeights(True)

...

fi = QFontInfo(self.font())

self._tree.setStyleSheet(
    f'''
    QTreeView {{
        alternate-background-color: #E6FFFF;
    }}
    QTreeView::Item{{
        height:{fi.pixelSize() * 2}px;
    }}
    ''')

我想这样设置颜色和高度可以稍微提高性能。

谢谢。我实现了这一点,但在我的例子中它还不起作用(条件'elif role==QtCore.Qt.SizeHintRole'永远不会满足),可能是因为我必须设置setData以便调用sizeHint(正如@RazrFalcon提到的)。一旦代码生效,我将转发它。感谢againI刚刚测试了它,在我的示例中效果很好。调用setData是行不通的:这只适用于QStandardItemModels,而不适用于QAbstractItemModel。你能给出我可以测试的代码的精简版本吗?当视图第一次访问模型时,应该请求SizeIntrole。如果您仍然有问题,那么您的AbstractItemModel还有其他问题。非常感谢,您的代码工作得非常出色!我在其他博客上没有找到这么简单的解决方案。我发现了我的(愚蠢的)错误:我在复制粘贴的代码中尝试了您的解决方案,其中有一个返回None if角色!=QtCore.Qt.DisplayRole。无论如何,再次谢谢你!我使用Python的PySide绑定,因此我将把您的代码转换为Pythontree=QTreeView()tree.model=QtGui.qabstractemmodel()tree.setModel(tree.model)tree.model.setData(tree.model.index(someIndex)、QtCore.QSize(20,20)、QtCore.Qt.SizeHintRole)和…|delegate=MyDelegate()树。setItemDelegate(delegate)@AlexanderHuszagh将其转换为一个带有格式的单独答案会很有帮助。当然@neuronet,它将在5中出现。