PyQt4示例中QWidgetItem被setDefaultFactory覆盖的颜色编辑工厂

2 投票
1 回答
615 浏览
提问于 2025-04-17 20:30

有没有人试过PyQt4的例子coloreditorfactory?

通常,我可以通过setFlags()setData()方法来创建可编辑的QWidgetItem,但在使用setDefaultFactory方法后,这些方法就不管用了。我看到一些文档说,所有新的或已有的委托都会被setDefaultFactory覆盖。

有没有什么方法可以让QWidgetItem再次可编辑?或者撤销setDefaultFactory的设置?谢谢~(除了QTextEdit或QLineEdit等)

import sip
sip.setapi('QVariant', 2)

from PyQt4 import QtCore, QtGui

class ColorListEditor(QtGui.QComboBox):
    def __init__(self, widget=None):
        super(ColorListEditor, self).__init__(widget)

        self.populateList()

    def getColor(self):
        color = self.itemData(self.currentIndex(), QtCore.Qt.DecorationRole)
        return color

    def setColor(self, color):
        self.setCurrentIndex(self.findData(color, QtCore.Qt.DecorationRole))

    color = QtCore.pyqtProperty(QtGui.QColor, getColor, setColor, user=True)

    def populateList(self):
        for i, colorName in enumerate(QtGui.QColor.colorNames()):
            color = QtGui.QColor(colorName)
            self.insertItem(i, colorName)
            self.setItemData(i, color, QtCore.Qt.DecorationRole)


class ColorListItemEditorCreator(QtGui.QItemEditorCreatorBase):
    def createWidget(self, parent):
        return ColorListEditor(parent)  

class Window(QtGui.QWidget):
    def __init__(self, parent=None):
        super(Window, self).__init__(parent)
        factory = QtGui.QItemEditorFactory()
        factory.registerEditor(QtCore.QVariant.Color,
                ColorListItemEditorCreator())
        QtGui.QItemEditorFactory.setDefaultFactory(factory)
        self.createGUI()

    def createGUI(self):
        tableData = [
            ("Alice", QtGui.QColor('aliceblue')),
            ("Neptun", QtGui.QColor('aquamarine')),
            ("Ferdinand", QtGui.QColor('springgreen'))
        ]

        table = QtGui.QTableWidget(3, 3)
        table.setHorizontalHeaderLabels(["Name", "Hair Color", "Editable"])
        table.verticalHeader().setVisible(False)
        table.resize(150, 50)

        for i, (name, color) in enumerate(tableData):
            nameItem = QtGui.QTableWidgetItem(name)
            colorItem = QtGui.QTableWidgetItem()
            colorItem.setData(QtCore.Qt.DisplayRole, color)            
            table.setItem(i, 0, nameItem)
            table.setItem(i, 1, colorItem)

            #add codes here
            editableItem = QtGui.QTableWidgetItem("xxxx")
            editableItem.setFlags(QtCore.Qt.ItemIsSelectable | QtCore.Qt.ItemIsEditable | QtCore.Qt.ItemIsEnabled)
            editableItem.setData(QtCore.Qt.EditRole, "xxxx")
            table.setItem(i, 2, editableItem)

        table.resizeColumnToContents(0)
        table.horizontalHeader().setStretchLastSection(True)

        layout = QtGui.QGridLayout()
        layout.addWidget(table, 0, 0)
        self.setLayout(layout)

        self.setWindowTitle("Color Editor Factory")


if __name__ == '__main__':

    import sys

    app = QtGui.QApplication(sys.argv)

    window = Window()
    window.show()

    sys.exit(app.exec_())

1 个回答

0

顾名思义,默认工厂会为所有新创建和已有的代理提供项目编辑器。所以,如果你想让某个工厂只和特定的代理一起使用,就只需要在那个代理上设置工厂即可:

class Window(QtGui.QWidget):
    def __init__(self, parent=None):
        super(Window, self).__init__(parent)
        self.createGUI()

    def createGUI(self):
        ...    
        self.delegate = QtGui.QStyledItemDelegate(self)
        factory = QtGui.QItemEditorFactory()
        factory.registerEditor(QtCore.QVariant.Color,
                ColorListItemEditorCreator())
        self.delegate.setItemEditorFactory(factory)
        table.setItemDelegateForColumn(1, self.delegate)
        ...

撰写回答