Qt 中 QTableView 中如何设置某一单元格文本的颜色值,希望能贴出代码。

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Qt 中 QTableView 中如何设置某一单元格文本的颜色值,希望能贴出代码。相关的知识,希望对你有一定的参考价值。

我想在tableview中的某一单元格在满足某一个条件后在改变它的文本颜色来提示用户,请问怎么做?兄弟感激不尽。
我还是不太懂,比如说,在(0,5)单元格中的条件满足后我需要把整行单元格的文字都变成红色,应该怎么做呢?

    QTableView 是用于 view - delegation - model 类型的;要想改变某一单元格文本的颜色,还是用 QTableWidget.

    假设界面上 QTableWidget name 是 tableWidget;

    ui->tableWidget->item(0, 0)->setForeground(Qt::red);

参考技术A 回复:
Qt::BackgroundRole改成Qt::ForegroundRole,就是文字颜色.(0,5)单元格就是index.column()==5&&index.row()==0

subclass你的Model,重载data、setData函数,以data()为例:

QVariant MyTestModel::data(const QModelIndex &index, int role) const

switch(role)

case Qt::DisplayRole:
return QVariant(QString(tr("%1")).arg((index.column() + 1) * 1000 + index.row() + 1));
case Qt::BackgroundRole:
switch(index.column() % 3)

case 0:
return QVariant(QColor(Qt::red));
case 1:
return QVariant(QColor(Qt::green));
case 2:
return QVariant(QColor(Qt::blue));
default://only to disable warning
return QVariant(QColor(Qt::white));


break;
default:
return QVariant();

本回答被提问者采纳

如何强制调整 indexWidgets 的大小以适合 Qt5 QTableView 的单元格

【中文标题】如何强制调整 indexWidgets 的大小以适合 Qt5 QTableView 的单元格【英文标题】:How to force resizing of indexWidgets to fit in cells of Qt5 QTableView 【发布时间】:2018-12-11 20:52:10 【问题描述】:

我在 OSX 10.13.6 上使用 Qt5.11.0 运行下面的示例代码(还有 RHEL 7.6,也出现了问题,但不像 OSX 上那么难看)。测试程序在 QTableView 中显示一个自定义模型,并为几个列设置了 indexWidgets:

#include <QtCore/QDebug>
#include <QtCore/QAbstractItemModel>
#include <QtWidgets/QApplication>
#include <QtWidgets/QMainWindow>
#include <QtWidgets/QHBoxLayout>
#include <QtWidgets/QHeaderView>
#include <QtWidgets/QTableView>
#include <QtWidgets/QPushButton>
#include <QtWidgets/QRadioButton>

class AModel : public QAbstractItemModel

    public:
    int            rowCount( const QModelIndex& parent = QModelIndex() ) const override  
                           return 5;    
                       ;
    int            columnCount( const QModelIndex& parent = QModelIndex() ) const override  
                           return 5;    
                       ;
    QModelIndex    parent( const QModelIndex& index ) const override  
                           return QModelIndex();    
                       ;     
    QModelIndex    index( int row, int column, const QModelIndex& parent = QModelIndex() ) const override 
                           if( ( ! parent.isValid() ) &&
                               row >= 0 && row < 5 &&
                               column >= 0 && column < 5 ) 
                               return createIndex( row, column );
                            else 
                               return QModelIndex();
                           
                       ;
    QVariant       data( const QModelIndex& index, int role = Qt::DisplayRole ) const override 
                           QVariant qval;
                           if( index.column() >= 1 && index.column() < 4 )  return QVariant(); 
                           switch( role ) 
                           case Qt::DisplayRole:
                               qval = QString( "%1,%2" ).arg( index.row() ).arg( index.column() );
                               break;
                           default:
                               qval = QVariant();
                               break;
                           
                           return qval;
                       ;
;

class AWidget : public QWidget

    public:
            AWidget( QWidget* parent ) : QWidget( parent ) 
                    QHBoxLayout* l = new QHBoxLayout();
                    this->setLayout( l );
                    QRadioButton* save = new QRadioButton( "Save" );
                    QRadioButton* del = new QRadioButton( "Delete" );
                    l->addWidget( save );
                    l->addWidget( del );
                ;
;

int
main( int argc, char *argv[] ) 
    QApplication   app( argc, argv );
    QMainWindow*   mw = new QMainWindow();
    AModel*        model = new AModel();
    QTableView*    view = new QTableView();

    view->setModel( model );

    // view->verticalHeader()->setDefaultSectionSize( 15 );

    for( int irow = 0; irow < model->rowCount(); irow++ ) 
        QPushButton*   pb = new QPushButton( "Mogrify", mw );
        QRadioButton*  rb = new QRadioButton( "Choose", mw );
        AWidget*       aw = new AWidget( mw );

        QObject::connect( pb, &QPushButton::clicked, [irow]() qDebug() << "Mogrifying " << irow;  );
        QObject::connect( rb, &QRadioButton::clicked, [irow]() qDebug() << "Choosing " << irow;  );

        view->setIndexWidget( model->index( irow, 1 ), pb );
        view->setIndexWidget( model->index( irow, 2 ), rb );
        view->setIndexWidget( model->index( irow, 3 ), aw );
    

    view->resizeColumnsToContents();

    mw->setCentralWidget( view );

    mw->show();

    return app.exec();

如果我只是按上面所示运行,结果是所有嵌入表格的小部件都有足够的空间:

但是,如果我在上面的代码中取消注释对 setDefaultSectionSize() 的调用,则嵌入表格的小部件不会按照我希望的方式调整自己的大小。 QPushButton 在底部被切断,QRadioButton 被塞满了很少的填充,自定义复合小部件根本不显示:

我尝试了各种方式的 QSizeHint 实验、子类化和互联网搜索,以使这些嵌入式小部件根据表格单元格中的可用空间自行调整大小,但目前无济于事。当我告诉 QTableView 它的单元格应该有多大时,如何让这些嵌入的 indexWidgets 自己绘制,以便它们适合 QTableView 中提供的单元格空间?

【问题讨论】:

【参考方案1】:

问题不在于 QTableView,而在于您的自定义小部件。自定义小部件的布局必须具有等于 0 的边距。

class AWidget : public QWidget

public:
    AWidget( QWidget* parent=nullptr) :
        QWidget( parent )
    
        QHBoxLayout* l = new QHBoxLayout(this);
        l->setContentsMargins(0, 0, 0, 0);  // <----
        QRadioButton* save = new QRadioButton( "Save" );
        QRadioButton* del = new QRadioButton( "Delete" );
        l->addWidget( save );
        l->addWidget( del );
    ;
;

【讨论】:

如此接近——这很好用,如在 Linux 上所示。在 OSX 上,单选按钮和自定义小部件现在适合,但 QPushButton 仍然在中间被截断。即使我将所述按钮包装在它自己的 QFrame/QGridLayout 中也是如此。我必须为 QPushButton 执行类似的步骤以使其适合 OSX 吗? 根据我上面的评论,OSX 上的 QPushButton 布局问题似乎与默认的 OSX 样式有关。我沉迷于在按钮上设置样式表的技巧,将背景设置为白色并将字体设置为已经存在的无操作。根据以前的答案,我知道这会强制按钮进入与 Linux 相同的样式库,这使得按钮在 OSX 上也可以呈现,并提供了可接受的解决方法。谢谢@eyllanesc

以上是关于Qt 中 QTableView 中如何设置某一单元格文本的颜色值,希望能贴出代码。的主要内容,如果未能解决你的问题,请参考以下文章

如何设置qtableview中的qcombobox的显示样式

如何强制调整 indexWidgets 的大小以适合 Qt5 QTableView 的单元格

在 Qtableview 上设置具有颜色(红色/绿色/黄色)的特定单元格

如何在 Qt 中使用 QFileSystemModel 设置文本颜色 QTableView?

Qt C++ 从 QTableView 中获取选定行的每个单元格的数据

Qt如何按比例分配QTableView的列宽并且充满整个控件