如何在小部件状态下实现 QListWidget 项目的一致突出显示?

Posted

技术标签:

【中文标题】如何在小部件状态下实现 QListWidget 项目的一致突出显示?【英文标题】:How do I achieve consistent highlighting of QListWidget items across widget states? 【发布时间】:2013-01-15 03:20:39 【问题描述】:

我正在使用 PyQT 4.8.3 创建一个包含两个 QListWidget 的对话框,它们都允许多选。

    我发现如果启用这些QListWidgets,只有当QListWidget有焦点时,被选中的项目才会以蓝色突出显示,没有焦点时突出显示为浅灰色。

    我还发现,如果 QListWidgets 被禁用,尽管没有焦点,但所选项目仍以蓝色突出显示。

当用户从一个列表转到另一个列表时,他们会发现这非常令人困惑。

作为一名开发人员,我发现浅灰色/无焦点、蓝色/禁用行为不受欢迎。对于修改它们的任何建议,我将不胜感激。

我查看了 QListWidget, QListView and QAbstractView 的文档,但没有找到任何适用的内容,我还查看了 stylesheet 文档,但没有任何运气。

【问题讨论】:

【参考方案1】:

我会在这里使用样式表。在此示例中,此 QListWidget 中的选定项目将以蓝色突出显示,当 QListWidget 被禁用或没有焦点时,它们将变为灰色:

#!/usr/bin/env python
#-*- coding:utf-8 -*-

from PyQt4 import QtCore, QtGui

class myWindow(QtGui.QWidget):

    def __init__(self, parent=None):
        super(myWindow, self).__init__(parent)

        self.setStyleSheet( """ QListWidget:item:selected:active 
                                     background: blue;
                                
                                QListWidget:item:selected:!active 
                                     background: gray;
                                
                                QListWidget:item:selected:disabled 
                                     background: gray;
                                
                                QListWidget:item:selected:!disabled 
                                     background: blue;
                                
                                """
                                )

        self.listWidget = QtGui.QListWidget(self)
        self.listWidget.setSelectionMode(QtGui.QAbstractItemView.MultiSelection)

        self.button = QtGui.QPushButton(self)
        self.button.setText("Disable the list!")
        self.button.clicked.connect(self.on_button_clicked)

        self.layout = QtGui.QVBoxLayout(self)
        self.layout.addWidget(self.button)
        self.layout.addWidget(self.listWidget)

        for itemNumber in range(5):
            item = QtGui.QListWidgetItem(self.listWidget)
            item.setText("Item 0".format(itemNumber))
            self.listWidget.addItem(item)


    @QtCore.pyqtSlot()
    def on_button_clicked(self):
        enable = False if self.listWidget.isEnabled() else True

        self.listWidget.setEnabled(enable)

if __name__ == "__main__":
    import sys

    app = QtGui.QApplication(sys.argv)
    app.setApplicationName('myWindow')

    main = myWindow()
    main.show()

    sys.exit(app.exec_())

【讨论】:

Stylesheet 是一种方式,但我认为您可以扩展您的答案类似于this example。 :active:!active:disabled 伪状态与 :selected 组合为 ::item 实际上将提供任何自定义选项。我不想添加答案,因为您已经有一个提到样式表:)。 @Avaris 感谢您的建议!我将它们添加到我的答案中:) 不错!正是我正在寻找的东西,我希望样式表的官方文档也有帮助。我将补充一点,虽然背景在各州之间是一致的,但 QListWidget 所选项目的文本颜色从有焦点的白色变为没有焦点的黑色。通过添加“颜色:白色;”轻松解决到样式表的每个部分。谢谢!【参考方案2】:

最简单的方法是更改​​ QPalette(如果样式表不适合您)。 只需使用您想要更改的值(仅)为 QListView 设置调色板。

做这样的事情:

QPalette customPalette;
QPalette orginalPallete = listView->palette();
customPalette->setBrush(QPalette::Disabled, QPalette::Highlight,
                        orginalPallete.brush(QPalette::Active, QPalette::Highlight));
listView->setPalette(customPalette);

我建议阅读调色板属性的工作原理(它合并了来自父级和 QApplication 的值,因此您只需要设置您想要更改的内容)。 您还可以通过更改 QApplication 的调色板来全局更改此颜色。

【讨论】:

【参考方案3】:

QItemDelegate 可用于提供自定义显示功能。我希望它会帮助你。你可以重新实现

virtual void paint( QPainter *painter, const QStyleOptionViewItem &option, const QModelIndex &index ) const

【讨论】:

以上是关于如何在小部件状态下实现 QListWidget 项目的一致突出显示?的主要内容,如果未能解决你的问题,请参考以下文章

在 qlistwidget 中禁用用户选择

如何在 QListWidget 中将项目列为组

Qt:如何突出显示 QListWidget 中的重复项? (qtjambi)

在小部件类 Flutter 中实现基类

如何从 QListWidget 中删除 QListWidget 项

如何使用自定义项目小部件拖放 QListWidget 项目?