为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

一只名叫tom的猫 2023-12-29 16:45:26
我想知道当我尝试像上图那样修复单元格时,是否可以增加单元格大小而不影响行大小。
查看完整描述

1 回答

?
拉莫斯之舞

TA贡献1820条经验 获得超10个赞

人们可以通过 QStyledItemDelegate 使用自定义编辑器,例如多个组件和定义的最小大小。

所以基本上你会:

  • 表模型(QAbstractTableModel 的子类)

  • 定义了带有 Qt.ItemIsEditable 的标志

  • 对于带有标签的列,您可以通过 setItemDelegateForColumn 设置自己的委托

  • 该委托继承自 QStyledItemDelegate

  • 覆盖 createEditor 并返回您的自定义编辑器

  • 重写 updateEditorGeometry 以设置自定义编辑器的大小和位置

  • 相应地实现 setEditorData 和 setModelData

  • 如果您想要一个额外的按钮来关闭编辑状态,请使用QApplication.postEvent(self, QKeyEvent(QKeyEvent.KeyPress, Qt.Key_Enter, Qt.NoModifier))

演示

显示两个 QLineEdit 元素和一个用于更改单元格文本和背景颜色的按钮的小示例可能如下所示:

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

可以看到,QTableWidget编辑状态下自定义编辑器的高度大于行高。

完整、独立的 PySide2 示例

代码可能如下所示:

import sys

from PySide2 import QtWidgets, QtCore

from PySide2.QtCore import Qt, QSize

from PySide2.QtGui import QColor, QKeyEvent

from PySide2.QtWidgets import QLineEdit, QPushButton, QVBoxLayout, QApplication



class 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.ItemIsEditable



class 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_())


查看完整回答
反对 回复 2023-12-29
  • 1 回答
  • 0 关注
  • 91 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信