如何将 QTableWidget 编辑状态下的单元格大小增加到超过行大小?

https://img1.sycdn.imooc.com/658e8742000185d907990545.jpg

我想知道当我尝试像上图那样修复单元格时,是否可以增加单元格大小而不影响行大小。



一只名叫tom的猫
浏览 93回答 1
1回答

拉莫斯之舞

人们可以通过 QStyledItemDelegate 使用自定义编辑器,例如多个组件和定义的最小大小。所以基本上你会:表模型(QAbstractTableModel 的子类)定义了带有 Qt.ItemIsEditable 的标志对于带有标签的列,您可以通过 setItemDelegateForColumn 设置自己的委托该委托继承自 QStyledItemDelegate覆盖 createEditor 并返回您的自定义编辑器重写 updateEditorGeometry 以设置自定义编辑器的大小和位置相应地实现 setEditorData 和 setModelData如果您想要一个额外的按钮来关闭编辑状态,请使用QApplication.postEvent(self, QKeyEvent(QKeyEvent.KeyPress, Qt.Key_Enter, Qt.NoModifier))演示显示两个 QLineEdit 元素和一个用于更改单元格文本和背景颜色的按钮的小示例可能如下所示:可以看到,QTableWidget编辑状态下自定义编辑器的高度大于行高。完整、独立的 PySide2 示例代码可能如下所示:import sysfrom PySide2 import QtWidgets, QtCorefrom PySide2.QtCore import Qt, QSizefrom PySide2.QtGui import QColor, QKeyEventfrom PySide2.QtWidgets import QLineEdit, QPushButton, QVBoxLayout, QApplicationclass MyDelegate(QtWidgets.QStyledItemDelegate):    def __init__(self, parent=None):        QtWidgets.QStyledItemDelegate.__init__(self, parent)    def createEditor(self, parent, option, index):        return CustomEditor(parent)    def updateEditorGeometry(self, editor, option, index):        # adjust position if close to border        editor.setGeometry(option.rect)    def paint(self, painter, option, index):        (text, bgColor) = ('', '')        data = index.data()        if type(data) == tuple and len(data) > 1:            (text, bgColor) = data        painter.setBrush(QColor(bgColor))        painter.drawRect(option.rect)        painter.setPen(QColor(255, 255, 255))        painter.drawText(option.rect, QtCore.Qt.AlignCenter, text)    def setEditorData(self, editor, index):        data = index.data()        if type(data) == tuple and len(data) > 1:            (text, bgColor) = index.data()            editor.edit1.setText(text)            editor.edit2.setText(bgColor)    def setModelData(self, editor, model, index):        model.setData(index, (editor.edit1.text(), editor.edit2.text()))class CustomEditor(QtWidgets.QWidget):    def __init__(self, parent):        QtWidgets.QWidget.__init__(self, parent)        self.edit1 = QLineEdit()        self.edit2 = QLineEdit()        self.button = QPushButton("close")        layout = QVBoxLayout()        layout.addWidget(self.edit1)        layout.addWidget(self.edit2)        layout.addWidget(self.button)        self.setLayout(layout)        self.button.clicked.connect(self.saveAndClose)        self.setAutoFillBackground(True)        self.setMinimumSize(QSize(128, 128))    def saveAndClose(self):        QApplication.postEvent(self, QKeyEvent(QKeyEvent.KeyPress, Qt.Key_Enter, Qt.NoModifier))class Model(QtCore.QAbstractTableModel):    def __init__(self):        QtCore.QAbstractTableModel.__init__(self)        self.colorData = [('abc', '#173f5f'),                          ('def', '#20639b'),                          ('ghi', '#3caea3'),                          ('red', '#ff0000'),                          ('mno', '#ed553b')]    def rowCount(self, parent):        return len(self.colorData)    def columnCount(self, parent):        return 2    def data(self, index, role):        if role == Qt.DisplayRole or role == Qt.EditRole:            return self.colorData[index.row()]        return None    def setData(self, index, value, role=None):        if role != Qt.EditRole:            self.colorData[index.row()] = value            self.dataChanged.emit(index, index)            return True        return False    def flags(self, index):        return Qt.ItemIsEnabled | Qt.ItemIsEditableclass TableView(QtWidgets.QWidget):    def __init__(self, parent=None):        QtWidgets.QWidget.__init__(self, parent)        tableModel = Model()        tableView = QtWidgets.QTableView()        tableView.setModel(tableModel)        mydelegate = MyDelegate(self)        tableView.setItemDelegateForColumn(1, mydelegate)        hbox = QtWidgets.QHBoxLayout()        hbox.addWidget(tableView)        self.setLayout(hbox)if __name__ == "__main__":    app = QApplication(sys.argv)    tableView = TableView()    tableView.setMinimumSize(QSize(400, 360))    tableView.show()    sys.exit(app.exec_())
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python