QT QTableView用法小结

QTableView常用于实现数据的表格显示。下面我们如何按步骤实现学生信息表格:

一 添加表头

    //准备数据模型
    QStandardItemModel *student_model = new QStandardItemModel();
    student_model->setHorizontalHeaderItem(0, new QStandardItem(QObject::tr("Name")));
    student_model->setHorizontalHeaderItem(1, new QStandardItem(QObject::tr("NO.")));
    student_model->setHorizontalHeaderItem(2, new QStandardItem(QObject::tr("Sex")));
    student_model->setHorizontalHeaderItem(3, new QStandardItem(QObject::tr("Age")));
    student_model->setHorizontalHeaderItem(4, new QStandardItem(QObject::tr("College")));
    //利用setModel()方法将数据模型与QTableView绑定
    ui->student_tableview->setModel(student_model);


二 设置表格属性

    //设置列宽不可变动,即不能通过鼠标拖动增加列宽       
    ui->student_tableview->horizontalHeader()->setResizeMode(0, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(1, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(2, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(3, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(4, QHeaderView::Fixed);   

    //设置表格的各列的宽度值       
    ui->student_tableview->setColumnWidth(0,100);   
    ui->student_tableview->setColumnWidth(1,100);   
    ui->student_tableview->setColumnWidth(2,100);   
    ui->student_tableview->setColumnWidth(3,100);   
    ui->student_tableview->setColumnWidth(4,100);       

    //默认显示行头,如果你觉得不美观的话,我们可以将隐藏       
    ui->student_tableview->verticalHeader()->hide();      

    //设置选中时为整行选中       
    ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows);         
     
    //设置表格的单元为只读属性,即不能编辑       
    ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers);          

    //如果你用在QTableView中使用右键菜单,需启用该属性       
    ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu);

 

三 动态添加行

    在表格中添加行时,我们只需要在model中插入数据即可,一旦model中的数据发生变化,QTabelView显示就会做相应的变动

    //在第一行添加学生张三的个人信息(setItem函数的第一个参数表示行号,第二个表示列号,第三个为要显示的数据)
    student_model->setItem(0, 0, new QStandardItem(“张三"));
    student_model->setItem(0, 1, new QStandardItem("20120202"));
    student_model->setItem(0, 2, new QStandardItem("男"));
    student_model->setItem(0, 3, new QStandardItem("18"));
    student_model->setItem(0, 4, new QStandardItem("土木学院"));


四 设置数据显示的样式

    //设置单元格文本居中,张三的数据设置为居中显示
    student_model->item(0, 0)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 1)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 2)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 3)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 4)->setTextAlignment(Qt::AlignCenter);

    //设置单元格文本颜色,张三的数据设置为红色
    student_model->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0)));
    student_model->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0)));
    student_model->item(0, 2)->setForeground(QBrush(QColor(255, 0, 0)));
    student_model->item(0, 3)->setForeground(QBrush(QColor(255, 0, 0)));
    student_model->item(0, 4)->setForeground(QBrush(QColor(255, 0, 0)));

    //将字体加粗
    student_model->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 2)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 3)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 4)->setFont( QFont( "Times", 10, QFont::Black ) );

    //设置排序方式,按年龄降序显示
    student_model->sort(3, Qt::DescendingOrder);

### Qt 中 TableView 的使用方法 #### 使用 QTableView 和自定义模型 `QTableView` 是 Qt 提供的一种用于显示表格数据的控件。为了实现更复杂的功能,通常会结合 `QAbstractTableModel` 或其子类来创建自定义的数据模型[^2]。 下面是一个简单的例子,展示如何通过继承 `QAbstractTableModel` 创建一个自定义模型,并将其与 `QTableView` 结合起来: ```cpp #include <QApplication> #include <QTableView> #include <QVBoxLayout> #include <QWidget> #include <QAbstractTableModel> // 自定义模型类 class CustomTableModel : public QAbstractTableModel { Q_OBJECT public: explicit CustomTableModel(QObject *parent = nullptr) : QAbstractTableModel(parent) {} int rowCount(const QModelIndex & /* parent */) const override { return 5; } int columnCount(const QModelIndex & /* parent */) const override { return 3; } QVariant data(const QModelIndex &index, int role) const override { if (role == Qt::DisplayRole) { return QString("Row%1, Column%2").arg(index.row() + 1).arg(index.column() + 1); } return {}; } QVariant headerData(int section, Qt::Orientation orientation, int role) const override { if (role != Qt::DisplayRole) return {}; if (orientation == Qt::Horizontal) { return QString("Header %1").arg(section + 1); } else { return QString("%1").arg(section + 1); } } }; int main(int argc, char *argv[]) { QApplication app(argc, argv); QWidget window; QVBoxLayout layout(&window); QTableView tableView; // 设置自定义模型到 QTableView CustomTableModel model; tableView.setModel(&model); layout.addWidget(&tableView); window.show(); return app.exec(); } ``` 此代码展示了如何创建一个基本的 `CustomTableModel` 并将其设置给 `QTableView` 控件。该模型具有固定的行列数,并返回一些示例字符串作为单元格的内容[^2]。 --- #### 关于 Conway's Game of Life 示例 如果希望了解更加复杂的场景应用,可以参考 Conway’s Game of Life 示例中的 `QML TableView` 类型。这个示例说明了如何利用 C++ 模型驱动 UI 显示逻辑并支持用户交互操作[^1]。 虽然这是一个基于 QML 的案例,但它同样适用于纯 C++ 应用程序开发思路——即分离业务逻辑(C++ 模型)和界面呈现(QTableView/QML)。具体来说,在这种情况下,可以通过信号槽机制绑定用户的输入事件至底层模型更新过程。 --- #### 私有成员变量的作用 当构建实际项目时,可能还需要管理其他资源比如文件路径或者状态标志位等辅助信息。例如在某些文档编辑器应用程序里可能会涉及到如下声明[^3]: ```cpp private: QTextEdit* textEdit; QAction* recentFileActs[MaxRecentFiles]; QAction* recentFileSeparator; QAction* recentFileSubMenuAct; QString curFile; bool isUntitled; ``` 这些字段帮助跟踪当前活动窗口内的组件实例及其关联行为模式(如记录最近使用的几个文件名称列表),从而增强用户体验的一致性和便利程度。 --- ### 总结 综上所述,无论是简单还是高级的应用需求下,掌握好基础理论知识加上灵活运用各种工具链就能轻松应对大多数挑战啦!
评论 4
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值