模仿基于QApplication :: palette()的颜色样式行为

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

这很简单:我想模仿被禁用项目的颜色变化而不禁用它。

QTableWidgetItemQStandardItem项目,我使用这样的代码

item->setForeground( enabled ? QApplication::palette().color( QPalette::Text ) : QApplication::palette().color( QPalette::Disabled, QPalette::Text ) );

马上。但是,如果用户使用新调色板调用QApplication::setPalette( ... ),则必须手动刷新该项目。我宁愿设置一个ColorGroupRole,所以Qt知道如何刷新。有可能吗?

c++ qt qt5 qtablewidget qpalette
1个回答
1
投票

要自动执行,您必须覆盖QStyledItemDelegate的initStyleOption()方法,并将伪启用与新角色关联:

#include <QtWidgets>

enum FakeRoles {
    FakeEnableRole = Qt::UserRole + 1000
};

class ForegroundDelegate: public QStyledItemDelegate
{
public:
    using QStyledItemDelegate::QStyledItemDelegate;
protected:
    void initStyleOption(QStyleOptionViewItem *option, const QModelIndex &index) const override{
        QStyledItemDelegate::initStyleOption(option, index);
        QVariant val = index.data(FakeRoles::FakeEnableRole);
        if(val.canConvert<bool>()){
            bool enabled = val.value<bool>();
            option->palette.setBrush(QPalette::Text,
                                     QApplication::palette().color(enabled ? QPalette::Active:
                                                                             QPalette::Disabled, QPalette::Text));
        }
    }
};

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    QTableWidget w(4, 4);
    ForegroundDelegate *delegate = new ForegroundDelegate(&w);
    w.setItemDelegate(delegate);
    for(int i=0; i< w.rowCount(); ++i)
        for (int j=0; j< w.columnCount(); ++j) {
            QTableWidgetItem *it = new QTableWidgetItem(QString("%1-%2").arg(i).arg(j));
            w.setItem(i, j, it);
            bool enabled =  QRandomGenerator::global()->bounded(0, 2) == 0;
            it->setData(FakeRoles::FakeEnableRole, enabled);
        }
    w.show();
    QTimer::singleShot(1000, [](){
        QPalette pal = QApplication::palette();
        pal.setColor(QPalette::Active, QPalette::Text, QColor("salmon"));
        pal.setColor(QPalette::Disabled, QPalette::Text, QColor("cyan"));
        QApplication::setPalette(pal);
    });
    return a.exec();
}
© www.soinside.com 2019 - 2024. All rights reserved.