二 进制序号
因为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中。文章来源:https://www.toymoban.com/news/detail-860293.html
十六 进制序号
文章来源地址https://www.toymoban.com/news/detail-860293.html
#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();
}
到了这里,关于Qt中的 tableView 设置 二进制 十六进制 序号表头的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!