gpt4 book ai didi

python - 在拖放中保留 QStandardItem 子类

转载 作者:太空宇宙 更新时间:2023-11-03 16:00:02 27 4
gpt4 key购买 nike

我有:

self.treeView = QTreeView()
self.treeView.setObjectName("testView")
self.treeView.setDragDropMode(QAbstractItemView.InternalMove)
self.treeView.setSelectionMode(QAbstractItemView.ExtendedSelection)

itemA = SubclassQStandardItemA(self)
itemB = SubcalssQStandardItemB(self)

self.model = QStandardItemModel()
self.treeView.setModel(self.model)

self.model.appendRow(itemA)
self.model.appendRow(itemB)

当我将 itemB 移动到 itemA 并检查其类时,ItemB 不再是 SubclassQStandardItemB 而是 QStandardItem。

如何在拖放时保留项目的原始类?

最佳答案

this answer 中所述,您可以使用setItemPrototype为模型提供项目工厂。但是,正如答案中所述,在拖放操作期间仅传输某些类型的信息。对于 QStandardItem,这意味着仅 item flagsitem data 。如果使用多个子类,则无法保留该项目的特定子类。一个模型只能有一个原型(prototype),该原型(prototype)用于 Qt 内部创建的所有项目。

这意味着如果您需要区分不同的项目类型,则不应使用多个 QStandardItem 子类。相反,您应该使用单个子类并重新实现 QStandardItem.type区分它们:

class MyItem(QtGui.QStandardItem):
TypeItemA = QtGui.QStandardItem.UserType
TypeItemB = QtGui.QStandardItem.UserType + 1
TypeItemC = QtGui.QStandardItem.UserType + 2

def clone(self):
return MyItem()

def type(self):
return self.data(QtCore.Qt.UserRole + 1000)

def setType(self, value):
self.setData(QtCore.Qt.UserRole + 1000, value)

...

itemA = MyItem(self)
itemA.setType(MyItem.TypeItemA)
itemB = MyItem(self)
itemB.setType(MyItem.TypeItemB)

关于python - 在拖放中保留 QStandardItem 子类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40413221/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com