首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >显示来自QAbstractTableModel的图像

显示来自QAbstractTableModel的图像
EN

Stack Overflow用户
提问于 2011-11-03 06:38:41
回答 1查看 3.1K关注 0票数 6

我正在尝试显示来自QAbstractTableModel的图像。我尝试返回一个QPixmap作为data()QVariant,但它只产生空单元格,而我希望第二列中的每个单元格都有一个20x20的黑色正方形。

这是我目前的代码:

代码语言:javascript
复制
QVariant MySqlTableModel::data(const QModelIndex &idx, int role = Qt::DisplayRole) const
{
    if (role == Qt::DisplayRole && idx.column() == 1) {
        QPixmap pixmap(20,20);
        QColor black(0,0,0);
        pixmap.fill(black);
        return pixmap;
    }

    return QSqlTableModel::data(idx, role);
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2011-11-03 07:55:24

对于具有标准委托的角色Qt::DisplayRole,只能返回可转换为字符串的QVariant%s。

您可以通过为角色Qt::DecorationRole返回图像来显示该图像

代码语言:javascript
复制
QVariant MySqlTableModel::data(const QModelIndex &idx, int role = Qt::DisplayRole) const
{
    if (idx.column() == 1) {
        if (role == Qt::DecorationRole) {
            QPixmap pixmap(20,20);
            QColor black(0,0,0);
            pixmap.fill(black);
            return pixmap;
        } else if (role == Qt::DisplayRole) {
            // For Qt::DisplayRole return an empty string, otherwise
            // you will have *both* text and image displayed.
            return "";
        }
    }

    return QSqlTableModel::data(idx, role);
}

或者编写自己的委托来自己完成绘制。有关更多详细信息,请参阅QStyledItemDelegate documentation

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7988182

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档