拖放时保留QStandardItem子类

时间:2016-11-03 23:59:20

标签: python drag-and-drop pyqt pyqt5 qstandarditem

我有:

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。

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

1 个答案:

答案 0 :(得分:1)

this answer中所述,您可以使用setItemPrototype为模型提供商品工厂。但是,如答案中所述,在拖放操作期间仅传输某些类型的信息。对于QStandardItem,这仅表示item flagsitem data。如果使用多个子类,则无法保留项的特定子类。模型只能有一个原型,并且用于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)
相关问题