将QIcon置于PyQt5中的QTableWidgetItem中

问题描述 投票:1回答:1

我有一个QTableWidget,其中一些QTableWidgetItem包含一个QIcon(不是按钮,不可点击,只是一个图像)。任何人都可以告诉我如何使图标居中?我在下面提供了一些正确显示图标的示例代码,但未能使其居中(setTextAlignment似乎适用于包含文本的项目,但显然不适用于图标)。

status_item = QtGui.QTableWidgetItem()
status_icon = QtGui.QIcon()
status_icon.addPixmap(QtGui.QPixmap(icon_file), QtGui.QIcon.Normal, QtGui.QIcon.Off)
status_item.setIcon(status_icon)
self.ServiceTableWidget.setItem(row, 0, status_item)
self.ServiceTableWidget.item(row, 0).setTextAlignment(QtCore.Qt.AlignHCenter) #not working

我也尝试使用QIcon.paint()方法,虽然我可能错误地实现了它,但它没有用。

status_icon.paint(QtGui.QPainter(), QtCore.QRect(), QtCore.Qt.AlignCenter)

提前致谢!

python pyqt pyqt5 qtablewidgetitem qicon
1个回答
0
投票

您可以使用委托:

from PyQt5 import QtCore, QtGui, QtWidgets

class IconDelegate(QtWidgets.QStyledItemDelegate):
    def initStyleOption(self, option, index):
        super(IconDelegate, self).initStyleOption(option, index)
        if option.features & QtWidgets.QStyleOptionViewItem.HasDecoration:
            s = option.decorationSize
            s.setWidth(option.rect.width())
            option.decorationSize = s

class MainWindow(QtWidgets.QMainWindow):
    def __init__(self, parent=None):
        super(MainWindow, self).__init__(parent)
        self.ServiceTableWidget = QtWidgets.QTableWidget(3, 3)

        delegate = IconDelegate(self.ServiceTableWidget)  # <--- 
        self.ServiceTableWidget.setItemDelegate(delegate) # <---

        icon_file = "lamp.png"
        status_item = QtWidgets.QTableWidgetItem()
        status_icon = QtGui.QIcon()
        status_icon.addPixmap(QtGui.QPixmap(icon_file), QtGui.QIcon.Normal, QtGui.QIcon.Off)
        status_item.setIcon(status_icon)
        self.ServiceTableWidget.setItem(0, 0, status_item)

        self.setCentralWidget(self.ServiceTableWidget)

if __name__ == '__main__':
    import sys
    app = QtWidgets.QApplication.instance()
    if app is None:
        app = QtWidgets.QApplication(sys.argv)
    w = MainWindow()
    w.show()
    sys.exit(app.exec_())

enter image description here

© www.soinside.com 2019 - 2024. All rights reserved.