这是一个快速的。我在我的每个QTreeWidgetItem中放置了一个包含10个按钮的QWidget,我可以扩展 - 收缩。
如果我收缩QWidget(隐藏),那么该行保持相同的高度。应该调整大小,以便只包含取消隐藏按钮。该行占用的空间仍为空。只有当我添加一个新的小部件时。行的高度重新计算。同样适用于扩展。如果我展开小部件,它仍然是17像素的高度。只有当我添加一个新的小部件时,才会重新计算行的高度。
QTreeWidget中是否有内置函数可以调用以更新行高 - 内容,还是需要循环遍历每个项目并手动调整其高度?
在QTreeWidgetItem中放置包含布局和许多小部件的QWidget也是个好主意吗?如果我想让500个QtreeWidgetItems,每个QTreeWidget都有20个Buttons / etc项目?
此致 达留
EDIT1。
我花了很多时间在上面。试过不同的路径,但到目前为止没有运气。我附上了粗略的代码来说明问题。只需点击隐藏1-2次,看看会发生什么。我很难理解“sizeHint”如何运作......
附上我的测试。
import sys
from PyQt5.QtGui import *
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *
sys._excepthook = sys.excepthook
def my_exception_hook(exctype, value, traceback):
# print(exctype, value, traceback)
sys._excepthook(exctype, value, traceback)
sys.exit(1)
sys.excepthook = my_exception_hook
class myWidget(QWidget):
def __init__(self, parent, something):
super(QWidget, self).__init__()
self.MW = parent
self.MWa = something
self.lay_main = QGridLayout()
self.setLayout(self.lay_main)
self.le_lineA = QLineEdit()
self.btn_a = QPushButton("Hey")
self.btn_a.clicked.connect(self.hideunhide)
self.subWidget = QWidget()
self.subLay = QGridLayout()
self.subWidget.setLayout(self.subLay)
self.btn_b = QPushButton("Boo")
self.lay_main.addWidget(self.btn_a)
self.lay_main.addWidget(self.subWidget)
self.subLay.addWidget(self.le_lineA)
self.subLay.addWidget(self.btn_b)
print("Im created :- )")
self.size = False
def hideunhide(self):
if self.subWidget.isHidden():
self.subWidget.show()
self.size = True
self.MW.sizeHint(1)
self.MW.setSizeHint(0, QSize(0, 0))
else:
self.subWidget.hide()
self.size = False
self.MW.sizeHint(1)
self.MW.setSizeHint(0, QSize(0, 0))
class widgetItemDictUpdate(QTreeWidgetItem):
def __init__(self, parent, MW, title, dicId):
super(QTreeWidgetItem, self).__init__(parent)
self.MW = MW
self.dicId = dicId
class myDelegate(QItemDelegate):
def __init__(self, mw):
self.MW = mw
super(QItemDelegate, self).__init__()
def sizeHint(self, option, index):
print("myDelegate", option, index)
if self.MW.itemFromIndex(index).layer.size:
return QSize(100, 100)
return QSize(100, 30)
class treeWidget(QTreeWidget):
def __init__(self, MW):
QTreeWidget.__init__(self)
self.setUniformRowHeights(False)
self.MW = MW
self.itemClicked.connect(self.printClick)
self.setHeaderItem(QTreeWidgetItem(["Name", "ProgressBar", "extra", "", "", "", "", "", "", "", ""]))
self.setDragDropMode(QAbstractItemView.InternalMove)
self.setSelectionMode(QAbstractItemView.ExtendedSelection)
self.dragItems = []
self.lastHidenItemsArray = []
self.hiddenItemsSet = []
self.delg = myDelegate(self)
self.setItemDelegate(self.delg)
self.addItems(self.invisibleRootItem())
def printClick(self, item, column):
print("Clicked")
def addItems(self, parent):
testParent = self.addSlave(parent, 'RandomA', 50)
testParent = self.addSlave(parent, 'RandomB', 60)
testParent = self.addSlave(parent, 'RandomBX', 60)
testParent = self.addSlave(parent, 'RandomBcvas', 60)
def addSlave(self, parent, title, id, expanded=True, visible=True):
item = widgetItemDictUpdate(parent, self, title, id)
myLayer = myWidget(item, self)
item.setText(0, title)
item.layer = myLayer
self.setItemWidget(item, 1, myLayer)
item.id = id
item.type = 1
return item
class Window(QWidget):
def __init__(self):
QWidget.__init__(self)
self.treeWidget = treeWidget(self)
layout = QVBoxLayout()
layout.addWidget(self.treeWidget)
self.setLayout(layout)
self.setGeometry(1000, 500, 500, 500)
if __name__ == "__main__":
app = QApplication(sys.argv)
window = Window()
window.show()
sys.exit(app.exec_())
答案 0 :(得分:0)
据我所知,虽然你可以通过将表实现为QTreeView + QSortFilterProxyModel子类对(PyQt: How Can I set row heights of QTreeView)来实现动态行高,但是没有办法直接调整行的大小。
或者我想象从表中删除小部件(removeItemWidget),然后立即重新添加它会导致行大小重新计算,虽然我没有测试过。
至于我对表内布局设置的看法,值得注意两件事:
据说500不是一个庞大的数字。我可能会把一个快速的原型拼凑在一起,看看它在一系列机器上的表现如何,以确定性能是否可以接受,然后担心如果它太慢就探索其他路线。我希望在这种情况下的性能最大程度上取决于布局的复杂程度。