Qt中的 tableView 设置 二进制 十六进制 序号表头

本文展示了如何通过创建自定义QHeaderView子类BinaryHeaderView和HexHeaderView,分别用于在QTableView中显示二进制和十六进制序号,通过重写paintSection方法实现自定义表头样式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

二 进制序号

在这里插入图片描述

因为QTableView的垂直表头并不支持使用委托来自定义。
相反,可以通过将自定义的QWidget作为QHeaderView的标签来实现这一目标。

代码:

#include <QApplication>
#include <QMainWindow>
#include <QVBoxLayout>
#include <QScrollArea>
#include <QTableView>
#include <QStandardItemModel>
#include <QHeaderView>
#include <QLabel>
#include <QPainter>

class BinaryHeaderView : public QHeaderView {
public:
    BinaryHeaderView(Qt::Orientation orientation, QWidget *parent = nullptr) 
        : QHeaderView(orientation, parent) {}

protected:
    void paintSection(QPainter *painter, const QRect &rect, int logicalIndex) const override {
        if (orientation() == Qt::Vertical) {
            QString binary = QString::number(logicalIndex, 2).rightJustified(4, '0');
            painter->save();
            painter->drawText(rect, Qt::AlignCenter, binary);
            painter->restore();
        } else {
            QHeaderView::paintSection(painter, rect, logicalIndex);
        }
    }
};

//------------------------------------------------------------------------以上复制到自己代码

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);

    QMainWindow mainWindow;

    // 创建表格
    QTableView tableView;

    // 创建模型和数据
    QStandardItemModel model(10, 10);

    for (int row = 0; row < 10; ++row) {
        for (int column = 0; column < 10; ++column) {
            QModelIndex index = model.index(row, column, QModelIndex());
            model.setData(index, QVariant(row * 10 + column + 1));
        }
    }

    tableView.setModel(&model);

    // 设置水平表头
    tableView.horizontalHeader()->hide();

//------------------------------------------------------------------------以下复制到自己代码
    // 创建垂直表头
    BinaryHeaderView *verticalHeader = new BinaryHeaderView(Qt::Vertical, &tableView);
    tableView.setVerticalHeader(verticalHeader);
//------------------------------------------------------------------------end

    // 将表格添加到主窗口
    mainWindow.setCentralWidget(&tableView);

    mainWindow.resize(600, 400);
    mainWindow.show();

    return app.exec();
}

在这个示例中,自定义了BinaryHeaderView类,继承自QHeaderView,
重写了paintSection方法来绘制二进制序列。然后,将这个自定义的垂直表头应用到了QTableView中。

十六 进制序号

在这里插入图片描述

#include <QApplication>
#include <QMainWindow>
#include <QVBoxLayout>
#include <QScrollArea>
#include <QTableView>
#include <QStandardItemModel>
#include <QHeaderView>
#include <QPainter>

class HexHeaderView : public QHeaderView {
public:
    HexHeaderView(Qt::Orientation orientation, QWidget *parent = nullptr) 
        : QHeaderView(orientation, parent) {}

protected:
    void paintSection(QPainter *painter, const QRect &rect, int logicalIndex) const override {
        if (orientation() == Qt::Vertical) {
            QString hex = QString("%1").arg(logicalIndex * 16, 4, 16, QChar('0'));
            painter->save();
            painter->drawText(rect, Qt::AlignCenter, hex);
            painter->restore();
        } else {
            QHeaderView::paintSection(painter, rect, logicalIndex);
        }
    }
};

int main(int argc, char *argv[]) {
    QApplication app(argc, argv);

    QMainWindow mainWindow;

    // 创建表格
    QTableView tableView;

    // 创建模型和数据
    QStandardItemModel model(10, 10);

    for (int row = 0; row < 10; ++row) {
        for (int column = 0; column < 10; ++column) {
            QModelIndex index = model.index(row, column, QModelIndex());
            model.setData(index, QVariant(row * 10 + column + 1));
        }
    }

    tableView.setModel(&model);

    // 设置水平表头
    tableView.horizontalHeader()->hide();

    // 创建垂直表头
    HexHeaderView *verticalHeader = new HexHeaderView(Qt::Vertical, &tableView);
    tableView.setVerticalHeader(verticalHeader);

    // 将表格添加到主窗口
    mainWindow.setCentralWidget(&tableView);

    mainWindow.resize(600, 400);
    mainWindow.show();

    return app.exec();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值