QtC++与QTableView详解

介绍

QTableView 是 Qt 框架中用于显示表格数据的视图控件,它是 QAbstractItemView 类的子类。QTableView 通常与 QStandardItemModel 或者自定义的数据模型一起使用,用于展示二维表格型数据。以下是对 QTableView 的详细讲解和在 Qt 中的作用:

QTableView 的作用:

  1. 显示表格数据: 主要用于显示二维表格形式的数据,其中数据可以是来自文件、数据库查询结果或其他来源。

  2. 编辑表格数据: 提供了对表格数据的编辑功能,用户可以直接在表格中进行数据的修改和输入。

  3. 支持排序和过滤: 具有内置的排序和过滤功能,可以通过设置相关属性来启用或禁用。

  4. 支持多种选择模式: 可以配置为单选、多选、行选择、列选择等不同的选择模式,以适应不同的应用场景。

  5. 自定义外观和交互: 允许通过自定义委托 (QAbstractItemDelegate) 或者子类化 QTableView 来实现自定义单元格的外观和交互。

  6. 数据排序和过滤: 支持用户对表格数据进行排序和过滤,提高数据的查看和管理效率。

  7. 支持拖放操作: 允许用户通过拖放操作在表格中移动、复制或重新排列数据。

QTableView 常用方法和信号:

以下是一些常用的方法和信号,可用于控制和响应 QTableView 的行为:

  • setModel(QAbstractItemModel *model): 设置与 QTableView 关联的数据模型。
  • setSelectionMode(QAbstractItemView::SelectionMode mode): 设置选择模式,可以是单选、多选或无选择。
  • setSortingEnabled(bool enable): 启用或禁用排序。
  • setEditTriggers(QAbstractItemView::EditTriggers triggers): 设置编辑触发器,控制何时启用编辑功能。
  • resizeColumnsToContents(): 调整列宽以适应内容。
  • resizeRowsToContents(): 调整行高以适应内容。
  • horizontalHeader(): 返回水平表头对象,可用于对表头进行定制。
  • verticalHeader(): 返回垂直表头对象,可用于对表头进行定制。
  • clicked(const QModelIndex &index): 单击某个单元格时触发的信号。
  • doubleClicked(const QModelIndex &index): 双击某个单元格时触发的信号。

示例应用场景:

  1. 数据库查询结果: 在数据库工具中,QTableView 可以显示数据库查询结果,用户可以直接在表格中编辑和管理数据。

  2. 报表生成: 用于生成和展示报表数据,支持用户查看和编辑报表中的数据。

  3. 数据分析工具: 在数据分析工具中,QTableView 可以显示和分析大量的数据,支持排序和过滤功能。

  4. 任务调度管理: 在任务调度管理系统中,QTableView 可以显示任务列表,支持用户对任务进行编辑和排序。

  5. 图形化配置界面: 用于创建图形化配置界面,用户可以通过表格形式配置软件参数和选项。

注意事项:

  • 使用 QTableView 时,通常需要一个合适的数据模型,例如 QStandardItemModelQSqlTableModel 或者自定义的模型类。

  • 当表格数据较大时,考虑启用排序和过滤以提高用户体验。

  • 对于复杂的单元格外观和交互需求,可以通过自定义委托或者子类化 QTableView 来实现。

结论:

QTableView 是一个功能强大的 Qt 控件,适用于显示和编辑表格形式的数据。它提供了丰富的功能和灵活性,使得开发者能够轻松创建各种表格界面,并以直观的方式展示和编辑二维表格型数据。

示例

#include <QApplication>
#include <QTableView>
#include <QStandardItemModel>
#include <QStandardItem>
#include <QHeaderView>
#include <QDebug>int main(int argc, char *argv[]) {QApplication app(argc, argv);// 示例1: 创建简单的 QTableViewQTableView simpleTableView;QStandardItemModel simpleModel;// 添加表头simpleModel.setHorizontalHeaderLabels({"Name", "Age", "City"});// 添加数据QList<QStandardItem*> rowData;rowData << new QStandardItem("John") << new QStandardItem("25") << new QStandardItem("New York");simpleModel.appendRow(rowData);rowData.clear();rowData << new QStandardItem("Alice") << new QStandardItem("30") << new QStandardItem("London");simpleModel.appendRow(rowData);simpleTableView.setModel(&simpleModel);simpleTableView.show();// 示例2: 启用编辑功能QTableView editableTableView;QStandardItemModel editableModel;editableModel.setHorizontalHeaderLabels({"Task", "Status"});QList<QStandardItem*> taskData;taskData << new QStandardItem("Task 1") << new QStandardItem("Incomplete");editableModel.appendRow(taskData);taskData.clear();taskData << new QStandardItem("Task 2") << new QStandardItem("Complete");editableModel.appendRow(taskData);editableTableView.setModel(&editableModel);editableTableView.setEditTriggers(QAbstractItemView::DoubleClicked | QAbstractItemView::EditKeyPressed);editableTableView.show();// 示例3: 使用自定义数据模型QTableView customModelTableView;CustomTableModel customModel;customModelTableView.setModel(&customModel);customModelTableView.show();// 示例4: 自定义表头QTableView customHeaderTableView;QStandardItemModel customHeaderModel;customHeaderModel.setHorizontalHeaderLabels({"Name", "Age", "City"});taskData.clear();taskData << new QStandardItem("Bob") << new QStandardItem("22") << new QStandardItem("Paris");customHeaderModel.appendRow(taskData);taskData.clear();taskData << new QStandardItem("Eva") << new QStandardItem("28") << new QStandardItem("Berlin");customHeaderModel.appendRow(taskData);customHeaderTableView.setModel(&customHeaderModel);customHeaderTableView.horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);customHeaderTableView.show();return app.exec();
}
// 示例6: 自定义单元格的外观和交互
class CustomDelegate : public QStyledItemDelegate {
public:QWidget* createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const override {if (index.column() == 1) {// 创建一个自定义的编辑器,例如一个带有下拉框的编辑器QComboBox *editor = new QComboBox(parent);editor->addItem("Incomplete");editor->addItem("Complete");return editor;}return QStyledItemDelegate::createEditor(parent, option, index);}void setEditorData(QWidget *editor, const QModelIndex &index) const override {if (index.column() == 1) {// 将数据设置到编辑器上QComboBox *comboEditor = qobject_cast<QComboBox*>(editor);if (comboEditor) {comboEditor->setCurrentText(index.data().toString());}} else {QStyledItemDelegate::setEditorData(editor, index);}}void setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const override {if (index.column() == 1) {// 从编辑器中获取数据并设置到模型QComboBox *comboEditor = qobject_cast<QComboBox*>(editor);if (comboEditor) {model->setData(index, comboEditor->currentText());}} else {QStyledItemDelegate::setModelData(editor, model, index);}}
};// 示例7: 使用自定义排序模型
class CustomSortModel : public QSortFilterProxyModel {
public:bool lessThan(const QModelIndex &left, const QModelIndex &right) const override {// 自定义排序规则,例如按照第二列数字排序QVariant leftData = sourceModel()->data(left);QVariant rightData = sourceModel()->data(right);return leftData.toInt() < rightData.toInt();}
};// 示例8: 支持拖放操作
void setupDragDrop(QTableView &tableView) {tableView.setDragEnabled(true);tableView.setAcceptDrops(true);tableView.setDropIndicatorShown(true);
}// 示例9: 实现表格合并
void mergeCells(QTableView &tableView) {// 使用 setSpan 方法合并单元格tableView.model()->setData(tableView.model()->index(0, 0), 1, Qt::UserRole); // 设置 UserRole 表示是合并的起始单元格tableView.setSpan(0, 0, 2, 1); // 合并两行
}// 示例10: 添加右键菜单
void setupContextMenu(QTableView &tableView) {tableView.setContextMenuPolicy(Qt::CustomContextMenu);QObject::connect(&tableView, &QTableView::customContextMenuRequested, [&tableView](const QPoint &pos) {QMenu contextMenu;QAction *action = contextMenu.addAction("Custom Action");contextMenu.exec(tableView.mapToGlobal(pos));});
}// 示例11: 定制表格的样式
void setCustomStyle(QTableView &tableView) {tableView.setStyleSheet("QTableView { background-color: lightgray; selection-background-color: blue; }");
}// 示例12: 实现动态更新
void setupDynamicUpdate(QTableView &tableView) {QTimer *timer = new QTimer(&tableView);QObject::connect(timer, &QTimer::timeout, [&tableView]() {// 模拟数据动态更新QStandardItemModel *model = qobject_cast<QStandardItemModel*>(tableView.model());if (model) {model->setData(model->index(0, 1), QTime::currentTime().toString("hh:mm:ss"));}});timer->start(1000); // 每秒更新一次
}// 示例13: 表格的导出和导入
void exportImportData(QTableView &tableView) {// 导出数据tableView.model()->setData(tableView.model()->index(1, 0), "Exported Data");// 导入数据QString importedData = tableView.model()->data(tableView.model()->index(1, 0)).toString();qDebug() << "Imported Data:" << importedData;
}// 示例14: 使用数据库模型
void setupDatabaseModel(QTableView &tableView) {QSqlDatabase db = QSqlDatabase::addDatabase("QSQLITE");db.setDatabaseName(":memory:"); // 在内存中创建数据库if (db.open()) {QSqlQuery query;query.exec("CREATE TABLE tasks (name TEXT, status TEXT)");query.exec("INSERT INTO tasks VALUES ('Task 1', 'Incomplete')");query.exec("INSERT INTO tasks VALUES ('Task 2', 'Complete')");QSqlTableModel *databaseModel = new QSqlTableModel(&tableView, db);databaseModel->setTable("tasks");databaseModel->select();tableView.setModel(databaseModel);} else {qDebug() << "Failed to open database";}
}// 示例15: 添加过滤器
void setupFilter(QTableView &tableView) {QSortFilterProxyModel *filterModel = new QSortFilterProxyModel(&tableView);filterModel->setSourceModel(tableView.model());filterModel->setFilterFixedString("Incomplete");tableView.setModel(filterModel);
}// 示例16: 实现表格中的图表
void setupChartInTable(QTableView &tableView) {QStandardItemModel *model = new QStandardItemModel(3, 3, &tableView);for (int row = 0; row < 3; ++row) {for (int col = 0; col < 3; ++col) {QStandardItem *item = new QStandardItem(QString::number(row * 3 + col));model->setItem(row, col, item);}}// 创建图表并将其嵌套到表格中QChart *chart = new QChart();chart->setTitle("Chart in Table");chart->legend()->hide();QChartView *chartView = new QChartView(chart);chartView->setRenderHint(QPainter::Antialiasing);// 将图表视图嵌套到表格中tableView.setIndexWidget(model->index(0, 2), chartView);
}// 示例17: 设置列宽和行高
void setupColumnRowSize(QTableView &tableView) {tableView.setColumnWidth(0, 150);tableView.setRowHeight(0, 30);
}// 示例18: 处理大量数据
void handleLargeData(QTableView &tableView) {// 使用虚拟滚动优化大量数据的显示tableView.setVerticalScrollMode(QAbstractItemView::ScrollPerPixel);tableView.setVerticalScrollBarPolicy(Qt::ScrollBarAlwaysOn);tableView.horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);// 生成大量数据QStandardItemModel *largeDataModel = new QStandardItemModel(1000, 10, &tableView);for (int row = 0; row < 1000; ++row) {for (int col = 0; col < 10; ++col) {QStandardItem *item = new QStandardItem(QString("(%1, %2)").arg(row).arg(col));largeDataModel->setItem(row, col, item);}}tableView.setModel(largeDataModel);
}// 示例19: 实现自定义的交互功能
void setupCustomInteraction(QTableView &tableView) {QObject::connect(&tableView, &QTableView::clicked, [&tableView](const QModelIndex &index) {qDebug() << "Custom Clicked: " << index.data();});
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/144504.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何构建风险矩阵?3大注意事项

风险矩阵法&#xff08;RMA&#xff09;是确定威胁优先级别的最有效工具之一&#xff0c;可以帮助项目团队识别和评估项目中的风险&#xff0c;帮助项目团队对风险进行排序&#xff0c;清晰地展示风险的可能性和严重性&#xff0c;为项目团队制定风险管理策略提供依据。 如果没…

Word或者WPS批量调整文中图片大小的快捷方法

文章目录 0、前言1、编写宏代码2、在文档中调用宏实现一键批量调整3、就这么简单&#xff01; 0、前言 不知道大家是不是也和我一样&#xff0c;经常需要在编写的Word&#xff08;或者WPS&#xff09;文档里插入大量的图片&#xff0c;但是这些图片的尺寸大小一般都不一样&…

信创之路数据库人大金仓篇

概要 信创大势所趋&#xff0c;吾等上下求索 参考文档 Linux&#xff1a;人大金仓数据库-KingBaseES V8与 php7的连接配置 laravel9适配人大金仓&#xff08;kingbase&#xff09;数据库 thinkphp6适配人大金仓&#xff08;Kingbase&#xff09;数据库 数据库选型 目前比较…

Django(七、模型层)

文章目录 模型层模型层前期准备使用django ORM要注意 代码演示&#xff1a;切换MySQL数据库如何查看django ORM 底层原理&#xff1f; 单表操作模型层之ORM常见关键字基础的增删改查常用的关键字 常见的十几种查询基于双下滑线的查询 模型层 模型层前期准备 使用django ORM要…

ATE测试工程师的薪资前景如何?能转DFT工程师吗?

在芯片行业&#xff0c;ATE测试工程师扮演着至关重要的角色。他们不仅需要理解电路和芯片内部的工作原理&#xff0c;还需要利用各种测试工具和方法对芯片进行精确的测试和分析。那么ATE测试工程师前景如何&#xff1f;需要具备哪些技能要求呢&#xff1f; 首先来了解什么是AT…

【技巧】Windows 11 如何安装日文语言包和日文系统

Windows 11 如何安装日文语言包和日文系统 安装日语语言第一步&#xff1a;打开系统设置第二步&#xff1a;选择【时间和语言】选项第三步&#xff1a;点击【添加语言】按钮第四步&#xff1a;输入语言&#xff0c;并选择第五步&#xff1a;安装输入法/语言包第六步&#xff1a…

电池故障估计:Realistic fault detection of li-ion battery via dynamical deep learning

昇科能源、清华大学欧阳明高院士团队等的最新研究成果《动态深度学习实现锂离子电池异常检测》&#xff0c;用已经处理的整车充电段数据&#xff0c;分析车辆当前或近期是否存在故障。 思想步骤&#xff1a; 用正常电池的充电片段数据构造训练集&#xff0c;用如下的方式构造…

php在线审稿系统mysql数据库web结构layUI布局apache计算机软件工程网页wamp

一、源码特点 php在线审稿系统是一套完善的web设计系统mysql数据库 &#xff0c;对理解php编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。 php在线审稿系统 代码 https://download.csdn.net/download/qq_41221322/885…

如何提高说服力?

说服力绝对不是吵架&#xff0c;不是谁的嗓门大就赢&#xff0c;这里说的说服力更多是基于丰富的知识&#xff0c;理论和超强的逻辑表达能力&#xff0c;除了从“理”的角度起到说服效果&#xff0c;更需要从影响和权威的角度产生信服。 说服力和影响力的测评&#xff0c;主要…

埋点上报系统

埋点类型分类&#xff1a; 在埋点中&#xff0c;主要埋点类型有点击埋点、曝光埋点&#xff0c;也可以具体定义业务上的埋点&#xff0c;比如下单埋点&#xff0c;加购埋点等。 其中&#xff0c;曝光事件通常在用户浏览应用或网站时触发。当用户进入一个页面或滚动页面时&…

【python】Django——django简介、django安装、创建项目、快速上手

笔记为自我总结整理的学习笔记&#xff0c;若有错误欢迎指出哟~ 【Django专栏】 Django——django简介、django安装、创建项目、快速上手 Django——templates模板、静态文件、django模板语法、请求和响应 Django——连接mysql数据库 Django——django安装、创建django项目、dj…

字母不重复的子串-第15届蓝桥第二次STEMA测评Scratch真题精选

[导读]&#xff1a;超平老师的《Scratch蓝桥杯真题解析100讲》已经全部完成&#xff0c;后续会不定期解读蓝桥杯真题&#xff0c;这是Scratch蓝桥杯真题解析第158讲。 第15届蓝桥第2次STEMA测评已于2023年10月29日落下帷幕&#xff0c;编程题一共有6题&#xff0c;分别如下&am…

解决:Android TextView 设置斜体后右侧文字被遮挡

一、问题说明 遇到一个比较奇怪的情况&#xff0c;给 TextView 文字设置倾斜后&#xff0c;右侧的文字会被遮挡&#xff0c;感觉这应该是 Android 的一个 bug &#xff01; 上代码&#xff1a; <TextViewandroid:id"id/tv_title"android:layout_width"wra…

windows与wsl互传文件

1.把windows上的文件传到wsl中&#xff0c;\\wsl.localhost\Ubuntu-22.04\mnt\wsl 将你要传的文件放到wsl这个路径下&#xff0c;Ubuntu-22.04是我的子系统&#xff0c;换成自己对应的 2.把wsl中的文件传到windows中 将wsl中的文件放到 /mnt/c 或 /mnt/d 中&#xff0c;这两…

小红书直播开启新纪元,拓世法宝AI直播一体机助您轻松成为行业标杆!

2023年&#xff0c;小红书终于成功坐上了电商牌桌。 今年3月的“董洁效应”带动了一批品牌商家、博主入驻小红书试水&#xff0c;其直播业务积蓄了巨大势能。10月15日&#xff0c;“初代名媛”章小蕙完成了在小红书的第二场直播&#xff0c;以销售额破亿的成绩打响了小红书双1…

大厂必备的6款React UI框架

优秀的ReactUI框架可以为您节省开发时间&#xff0c;提高开发效率&#xff0c;统一设计语言。你还在为你的项目寻找高质量的ReactUI框架吗&#xff1f;为了让您更容易找到易于使用的UI框架&#xff0c;分享6个优秀的ReactUI框架选项&#xff0c;并介绍了每个UI框架的不同功能和…

WPF中的App类介绍

在WPF (Windows Presentation Foundation) 应用程序中&#xff0c;App 类扮演着很重要的角色。这个类通常在每个WPF应用程序中都会有&#xff0c;并且生成在App.xaml文件和其代码后台App.xaml.cs中。App类通常继承自System.Windows.Application类&#xff0c;并且有以下的主要职…

Google 向中国开发者开放数百份 TensorFlow 资源

Google 的机器学习框架 TensorFlow 自 2015 年开源后&#xff0c;已然成为 AI 领域最受欢迎的框架。 据统计&#xff0c;在广受欢迎的 Python 编程语言在线软件知识库 PyPi 上&#xff0c;TensorFlow 的下载次数已超过 90 万&#xff0c;其中有 15% 来自中国。谷歌官方博客也表…

分布式事务解决方案

分布式事务解决方案 百度安全验证 分布式事务解决方案 【精选】这六种目前最常见分布式事务解决方案&#xff01;请拿走不谢-CSDN博客

Android问题笔记四十四:关于RecyclerView出现Inconsistency detected崩溃

点击跳转>Unity3D特效百例点击跳转>案例项目实战源码点击跳转>游戏脚本-辅助自动化点击跳转>Android控件全解手册点击跳转>Scratch编程案例点击跳转>软考全系列 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&…