簡體   English   中英

如何在PyQt5中設置QTableWidget的每個項目的選擇顏色

[英]How to set each item's selection color of QTableWidget in PyQt5

選擇一個項目時,我想使用其他選擇顏色。 但是QTableWidget::item:selected{ background-color: }僅在只有一個項目被選中時才起作用,否則所有選中的項目將具有相同的選擇顏色。 那么有沒有一種方法可以使每個項目都有各自的選擇顏色?

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        self.MainWindow=MainWindow
        self.MainWindow.resize(300, 100)
        self.centralwidget = QtWidgets.QWidget(self.MainWindow)
        self.MainWindow.setCentralWidget(self.centralwidget)
        """table """
        self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
        self.tableWidget.insertRow(0)
        self.tableWidget.setColumnCount(2)

        self.tableWidget.setItem(0,0,QtWidgets.QTableWidgetItem("red"))
        self.tableWidget.setItem(0,1,QtWidgets.QTableWidgetItem("blue"))
        self.tableWidget.itemSelectionChanged.connect(self.ChangeSelectionColor)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
    def ChangeSelectionColor(self):
        try:
            for item in self.tableWidget.selectedItems():
                col=item.column()
            self.tableWidget.setStyleSheet("QTableWidget::item:selected{ background-color: %s }"%color_list[col])
        except UnboundLocalError:
            pass
if __name__ == "__main__":
    import sys
    color_list=['red','blue']
    app = QtWidgets.QApplication(sys.argv)
    MainWindow = QtWidgets.QMainWindow()
    ui = Ui_MainWindow()
    ui.setupUi(MainWindow)
    MainWindow.show()
    sys.exit(app.exec_())

在此處輸入圖片說明

在此處輸入圖片說明

一種選擇效果很好。

在此處輸入圖片說明

多項選擇僅將顏色應用於所有選中的項目。 我希望左邊的一個被選為紅色。

在這種情況下,使用qss是不合適的,因為它們有很多限制,它適合於實現委托,在這種情況下,該類是從QStyledItemDelegate繼承的類。 但是在此之前,我們必須通過QTableWidgetItem的setData方法保存顏色信息:

it = QTableWidgetItem("some_text")
it.setData(Qt.UserRole, some_color)

然后,重寫QStyledItemDelegate的paint方法,並更改選擇顏色:

class ColorDelegate(QStyledItemDelegate):
    def paint(self, painter, option, index):
        color = index.data(Qt.UserRole)
        option.palette.setColor(QPalette.Highlight, color)
        QStyledItemDelegate.paint(self, painter, option, index)

然后建立委托:

your_qtablewidget.setItemDelegate(ColorDelegate())

我在下面顯示了一個完整的示例:

from PyQt5.QtWidgets import QApplication, QStyledItemDelegate, QTableWidget, QTableWidgetItem, QStyle
from PyQt5.QtGui import QColor, QPalette
from PyQt5.QtCore import qrand, Qt

class ColorDelegate(QStyledItemDelegate):
    def paint(self, painter, option, index):
        color = index.data(Qt.UserRole)
        option.palette.setColor(QPalette.Highlight, color)
        QStyledItemDelegate.paint(self, painter, option, index)


def fun(n_rows, n_columns):
    return [[QColor(qrand() % 256, qrand() % 256, qrand() % 256) for i in range(n_rows)] for j in range(n_columns)]

if __name__ == '__main__':
    import sys

    app = QApplication(sys.argv)
    n_rows, n_columns = 10, 10
    colors = fun(n_rows, n_columns)
    w = QTableWidget()
    w.setColumnCount(n_columns)
    w.setRowCount(n_columns)
    for i in range(w.rowCount()):
        for j in range(w.columnCount()):
            it = QTableWidgetItem("{}-{}".format(i, j))
            it.setData(Qt.UserRole, colors[i][j])
            w.setItem(i, j, it)
    w.setItemDelegate(ColorDelegate())
    w.show()
    sys.exit(app.exec_())

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM