Qt开发:项目视图(Item Views)的介绍和使用

文章目录

    • 一、清单视图(List View)
      • 1.1 基本概念
      • 1.2 使用示例(文字列表)
      • 1.3 图标+文字(图标模式)
      • 1.4 常用设置
      • 1.5 完整示例
    • 二、树视图(Tree View)
      • 2.1 基本概念
      • 2.2 常用类简介
      • 2.3 快速使用示例
      • 2.4 常用功能配置
    • 三、表视图(Table View)
      • 3.1 基本概念
      • 3.2 常用类
      • 3.3 快速使用示例
      • 3.4 常用功能设置
    • 四、列视图(Column View)
      • 4.1 基本概念
      • 4.2 常用类
      • 4.3 使用示例
      • 4.4 使用自定义树结构数据
      • 4.5 常用方法
      • 4.6 与 QTreeView 的区别
    • 五、撤销命令视图(Undo View)
      • 5.1 基本概念
      • 5.2 使用示例

一、清单视图(List View)

1.1 基本概念

  在 Qt 中,QListView 是用于显示垂直列表或图标网格的视图控件,它是基于 Qt 的模型/视图架构构建的,适合用于展示一组条目,如文件列表、联系人列表、图标等。

  • QListView 是视图(View)
  • 搭配模型(Model)使用,例如 QStringListModel、QStandardItemModel
  • 也可以设置委托(Delegate)来自定义每一项的显示方式

1.2 使用示例(文字列表)

#include <QListView>
#include <QStringListModel>// 创建模型
QStringList list = {"苹果", "香蕉", "橘子"};
QStringListModel *model = new QStringListModel(list);// 创建视图
QListView *listView = new QListView(this);
listView->setModel(model);

1.3 图标+文字(图标模式)

QStandardItemModel *model = new QStandardItemModel(this);QStandardItem *item1 = new QStandardItem(QIcon(":/img/apple.png"), "苹果");
QStandardItem *item2 = new QStandardItem(QIcon(":/img/banana.png"), "香蕉");model->appendRow(item1);
model->appendRow(item2);QListView *listView = new QListView(this);
listView->setModel(model);// 设置为图标模式
listView->setViewMode(QListView::IconMode);
listView->setIconSize(QSize(64, 64));
listView->setSpacing(10);

1.4 常用设置

在这里插入图片描述

1.5 完整示例

#include <QWidget>
#include <QListView>
#include <QStringListModel>
#include <QMessageBox>class MainWindow : public QWidget
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr) : QWidget(parent) {this->resize(450, 250);this->setWindowTitle("QListView 示例");QListView *pListView = new QListView(this);pListView->setGeometry(20, 20, 300, 160);QStringList list;list.append("运动类:篮球、足球");list.append("娱乐类:看电影、写小说、听音乐");list.append("游戏类:五子棋、扑克牌、中国象棋");list.append("旅游类:国外旅游、国内旅游");QStringListModel *listMode = new QStringListModel(list);pListView->setModel(listMode);connect(pListView, &QListView::clicked, this, &MainWindow::onSlotClickedFunc);}private slots:void onSlotClickedFunc(const QModelIndex &index) {QMessageBox::information(NULL, "兴趣爱好", "你选择的类型为:\n" + index.data().toString());}
};
#endif // MAINWINDOW_H

输出结果:
请添加图片描述

二、树视图(Tree View)

2.1 基本概念

  Qt 的树视图使用 QTreeView 类来实现,通常需要结合一个数据模型(如 QStandardItemModel 或自定义的 QAbstractItemModel)来提供数据源。

主要特点:

  • 支持多级嵌套(每一项都可以有子项)
  • 支持展开、折叠
  • 支持选择、编辑、右键菜单等交互

2.2 常用类简介

在这里插入图片描述

2.3 快速使用示例

以下是一个最基本的树视图示例,使用 QStandardItemModel:

#include <QApplication>
#include <QTreeView>
#include <QStandardItemModel>int main(int argc, char *argv[]) {QApplication app(argc, argv);QTreeView treeView;QStandardItemModel model;model.setHorizontalHeaderLabels({ "名称" });// 创建顶层节点QStandardItem *rootItem = new QStandardItem("动物");// 添加子节点QStandardItem *mammalItem = new QStandardItem("哺乳动物");QStandardItem *birdItem = new QStandardItem("鸟类");rootItem->appendRow(mammalItem);rootItem->appendRow(birdItem);// 添加孙子节点mammalItem->appendRow(new QStandardItem("老虎"));mammalItem->appendRow(new QStandardItem("大象"));birdItem->appendRow(new QStandardItem("麻雀"));birdItem->appendRow(new QStandardItem("乌鸦"));// 添加到模型model.appendRow(rootItem);treeView.setModel(&model);treeView.expandAll();  // 默认展开所有节点treeView.setWindowTitle("树视图示例");treeView.resize(400, 300);treeView.show();return app.exec();
}

输出结果:
在这里插入图片描述

2.4 常用功能配置

在这里插入图片描述

三、表视图(Table View)

3.1 基本概念

  在 Qt 中,表视图(QTableView)是用于显示二维表格数据的控件,广泛用于数据管理、数据库展示、信息表格等场景。它是 Qt 的 Model/View 架构中的一部分,需要配合数据模型(如 QStandardItemModel 或自定义的 QAbstractTableModel)一起使用。

3.2 常用类

在这里插入图片描述

3.3 快速使用示例

使用 QTableView + QStandardItemModel 创建一个简单表格:

#include <QApplication>
#include <QTableView>
#include <QStandardItemModel>
#include <QStandardItem>int main(int argc, char *argv[]) {QApplication app(argc, argv);QTableView tableView;QStandardItemModel model;// 设置行列数和表头model.setRowCount(3);model.setColumnCount(3);model.setHorizontalHeaderLabels({ "姓名", "年龄", "城市" });// 设置数据model.setItem(0, 0, new QStandardItem("张三"));model.setItem(0, 1, new QStandardItem("25"));model.setItem(0, 2, new QStandardItem("北京"));model.setItem(1, 0, new QStandardItem("李四"));model.setItem(1, 1, new QStandardItem("30"));model.setItem(1, 2, new QStandardItem("上海"));model.setItem(2, 0, new QStandardItem("王五"));model.setItem(2, 1, new QStandardItem("28"));model.setItem(2, 2, new QStandardItem("广州"));tableView.setModel(&model);tableView.setWindowTitle("表格视图示例");tableView.resize(400, 250);tableView.show();return app.exec();
}

输出结果:
在这里插入图片描述

3.4 常用功能设置

在这里插入图片描述

四、列视图(Column View)

4.1 基本概念

  在 Qt 中,列视图(QColumnView)是一个专门用于浏览分层结构数据(如文件系统)的控件,它以多列级联展开的形式展示每一级子项。它是 Qt 的 Model/View 架构中的一部分,常见于例如 Mac OS Finder 样式的界面中,每一级目录(或层级)占据一个独立的列,用户点击某一项时,其子项会在右侧新列中显示。

基本特点:

  • 展示层级结构数据(必须是树形结构模型,如 QDirModel、QStandardItemModel 或 QFileSystemModel)。
  • 每一级展开为一列,水平滚动。
  • 和 QTreeView 一样,要求模型提供父子关系。

4.2 常用类

在这里插入图片描述

4.3 使用示例

使用 QFileSystemModel 显示文件夹结构:

#include <QApplication>
#include <QColumnView>
#include <QFileSystemModel>int main(int argc, char *argv[]) {QApplication app(argc, argv);QColumnView *columnView = new QColumnView;QFileSystemModel *model = new QFileSystemModel;model->setRootPath(QDir::rootPath()); // 设置根路径columnView->setModel(model);columnView->setRootIndex(model->index(QDir::homePath())); // 设置初始显示目录columnView->setWindowTitle("QColumnView 示例 - 文件浏览器");columnView->resize(800, 400);columnView->show();return app.exec();
}

输出结果:
在这里插入图片描述

4.4 使用自定义树结构数据

#include <QApplication>
#include <QColumnView>
#include <QStandardItemModel>int main(int argc, char *argv[]) {QApplication app(argc, argv);QColumnView *columnView = new QColumnView;QStandardItemModel *model = new QStandardItemModel;QStandardItem *root = new QStandardItem("动物");QStandardItem *mammal = new QStandardItem("哺乳动物");mammal->appendRow(new QStandardItem("老虎"));mammal->appendRow(new QStandardItem("狮子"));QStandardItem *bird = new QStandardItem("鸟类");bird->appendRow(new QStandardItem("麻雀"));bird->appendRow(new QStandardItem("乌鸦"));root->appendRow(mammal);root->appendRow(bird);model->appendRow(root);columnView->setModel(model);columnView->setRootIndex(model->index(0, 0)); // 设定根节点columnView->setWindowTitle("QColumnView 示例 - 文件浏览器");columnView->resize(800, 400);columnView->show();return app.exec();
}

输出结果:
在这里插入图片描述

4.5 常用方法

在这里插入图片描述

4.6 与 QTreeView 的区别

在这里插入图片描述

五、撤销命令视图(Undo View)

5.1 基本概念

  在 Qt 中,撤销命令视图(QUndoView)是用于展示和管理命令模式撤销/重做操作历史记录的一个视图类。它配合 QUndoStack 或 QUndoGroup 使用,能够图形化地显示用户执行过的操作,并允许用户点击某个历史命令进行撤销或重做。

Qt 中的撤销框架基于命令模式,主要类如下:
- List item

5.2 使用示例

基本撤销命令视图:

自定义命令类

#include <QUndoCommand>
#include <QString>
#include <QDebug>class PrintCommand : public QUndoCommand {
public:PrintCommand(const QString &text) : m_text(text) {setText("Print: " + text); // 设置在 UndoView 中显示的文本}void undo() override {qDebug() << "Undo:" << m_text;}void redo() override {qDebug() << "Redo:" << m_text;}private:QString m_text;
};

创建主窗口并绑定 QUndoView

#include <QApplication>
#include <QUndoView>
#include <QUndoStack>
#include <QVBoxLayout>
#include <QPushButton>
#include <QWidget>int main(int argc, char *argv[]) {QApplication app(argc, argv);QWidget window;QVBoxLayout layout(&window);QUndoStack *undoStack = new QUndoStack(&window);QUndoView *undoView = new QUndoView(undoStack); // 绑定命令栈QPushButton *addButton = new QPushButton("添加命令");layout.addWidget(addButton);layout.addWidget(undoView);QObject::connect(addButton, &QPushButton::clicked, [&]() {static int count = 1;undoStack->push(new PrintCommand(QString("命令%1").arg(count++)));});window.setWindowTitle("QUndoView 示例");window.resize(300, 300);window.show();return app.exec();
}

输出结果:
请添加图片描述

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

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

相关文章

GoWeb开发(基础)

Go&#xff08;Golang&#xff09;是一种高效、简洁的编程语言&#xff0c;特别适合Web开发。以下是详细的Go Web开发指南&#xff0c;涵盖从基础到进阶的内容。 --- 一、Go Web开发基础 1. 标准库 net/http Go 内置 net/http 包&#xff0c;支持快速构建 Web 服务。 - 基本示…

GSENSE2020BSI sCMOS科学级相机主要参数及应用场景

GSENSE2020BSI sCMOS科学级相机是一款面向宽光谱成像需求的高性能科学成像设备&#xff0c;结合了背照式&#xff08;Back-Side Illuminated, BSI&#xff09;CMOS技术与先进信号处理算法&#xff0c;适用于天文观测、生物医学成像、工业检测等领域。以下是其核心特点及技术细节…

【日撸 Java 三百行】Day 9(While语句)

目录 Day 9&#xff1a;While 语句的基本使用方法 一、基础知识及案例分析 二、代码及测试 拓展&#xff1a;流程控制语句专题补充 小结 Day 9&#xff1a;While 语句的基本使用方法 Task&#xff1a; while 语句本质上比 for 更基础, 因此可以替代后者. 但 for 在很多时候…

React 第三十七节 Router 中 useOutlet Hook的使用介绍以及注意事项

React Router 中的 useOutlet 是 v6 版本新增的 Hook&#xff0c;用于在父路由组件中访问当前嵌套的子路由元素。它提供了比 <Outlet> 组件更灵活的控制方式&#xff0c;适合需要根据子路由状态进行动态处理的场景。 一、useOutlet的基本用法 import { useOutlet } fro…

TDengine 在智慧油田领域的应用

简介 智慧油田&#xff0c;亦称为数字油田或智能油田&#xff0c;是一种采用尖端信息技术与先进装备的现代油田开发模式。该模式通过实时更新油气田层析图及动态生产数据&#xff0c;显著提高了油气田的开发效率与经济价值。 信息技术在此领域发挥着至关重要的作用&#xff0…

关于AI 大数据模型的基础知识 杂记

一、LM Studio LM Studio下载地址&#xff1a;LM Studio - Discover, download, and run local LLMshttps://lmstudio.ai/LM Studio是使用electron架构&#xff0c;引用的llama.cpp库。 下载后的模型存储于 /User/Admin/.lmstudio/models中。 二、llama.cpp库下载地址 llam…

2025数维杯数学建模竞赛B题完整参考论文(共38页)(含模型、代码、数据)

2025数维杯数学建模竞赛B题完整参考论文 目录 摘要 一、问题重述 二、问题分析 三、模型假设 四、定义与符号说明 五、 模型建立与求解 5.1问题1 5.1.1问题1思路分析 5.1.2问题1模型建立 5.1.3问题1求解结果 5.2问题2 5.2.1问题2思路分析 5.2.2问题2…

利用GPT实现油猴脚本—网页滚动(优化版)

在浏览网页的时候&#xff0c;发现有的网页没有直达最前这样的功能&#xff0c;所有心血来潮利用ChatGPT写了一个油猴脚本以实现此功能&#xff0c;在网站上出现一个可以自由拖动的滑块。 声明&#xff1a;引用或二创需注明出处。 如图&#xff1a; 点击即可直达当前网页最前、…

MySQL基础关键_013_常用 DBA 命令

目 录 一、MySQL 用户信息存储位置 二、新建用户 1.创建本地用户 2.创建外网用户 三、用户授权 1.说明 2.实例 四、撤销授权 五、修改用户密码 六、修改用户名、主机名/IP地址 七、删除用户 八、数据备份 1.导出数据 2.导入数据 &#xff08;1&#xff09;方式…

计算机视觉与深度学习 | 图像匹配算法综述

图像匹配算法综述 图像匹配 图像匹配算法综述一、算法分类二、经典算法原理与公式1. **SIFT (Scale-Invariant Feature Transform)**2. **ORB (Oriented FAST and Rotated BRIEF)**3. **模板匹配(归一化互相关,NCC)**4. **SuperPoint(深度学习)**三、代码示例1. **SIFT 特…

切比雪夫不等式详解

切比雪夫不等式详解 一、引言 切比雪夫不等式&#xff08;Chebyshev’s Inequality&#xff09;是概率论和统计学中最重要的基本定理之一&#xff0c;由俄国数学家切比雪夫&#xff08;P. L. Chebyshev&#xff0c;1821-1894&#xff09;提出。它为我们提供了一个强大工具&am…

霸王茶姬微信小程序自动化签到系统完整实现解析

霸王茶姬微信小程序自动化签到系统完整实现解析 技术栈&#xff1a;Node.js 微信小程序API MD5动态签名 一、脚本全景架构 功能模块图 #mermaid-svg-0vx5W2xo0IZWn6mH {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-s…

气动带刮刀硬密封固定式对夹球阀:专为高粘度、强腐蚀性介质设计的工业解决方案-耀圣

气动带刮刀硬密封固定式对夹球阀&#xff1a;专为高粘度、强腐蚀性介质设计的工业解决方案 在石油化工、锂电材料、污水处理等高难度工况中&#xff0c;带颗粒的高粘度介质、料浆及强腐蚀性流体对阀门的性能提出了严苛要求。 气动带刮刀硬密封固定式对夹球阀凭借其独特的结构…

Filecoin存储管理:如何停止Lotus向特定存储路径写入新扇区数据

Filecoin存储管理&#xff1a;如何停止Lotus向特定存储路径写入新扇区数据 引言背景问题场景解决方案步骤1&#xff1a;修改sectorstore.json文件步骤2&#xff1a;重新加载存储配置步骤3&#xff1a;验证更改 技术原理替代方案最佳实践结论 引言 在Filecoin挖矿过程中&#x…

互联网大厂Java求职面试:高并发系统设计与架构实战

互联网大厂Java求职面试&#xff1a; 高并发系统设计与架构实战 第一轮提问&#xff1a;基础概念与核心原理 技术总监&#xff08;严肃&#xff09;&#xff1a;郑薪苦&#xff0c;你对JVM的内存模型了解多少&#xff1f;能说说堆、栈、方法区的区别吗&#xff1f; 郑薪苦&a…

AD原理图复制较多元器件时报错:“InvalidParameter Exception Occurred In Copy”

一、问题描述 AD原理图复制较多元器件时报错&#xff1a;AD原理图复制较多元器件时报错&#xff1a;“InvalidParameter Exception Occurred In Copy”。如下图 二、问题分析 破解BUG。 三、解决方案 1、打开参数配置 2、打开原理图优先项中的通用配置&#xff0c;取消勾选G…

网络研讨会开发注册中, 5月15日特励达力科,“了解以太网”

在线研讨会主题 Understanding Ethernet - from basics to testing & optimization 了解以太网 - 从基础知识到测试和优化 注册链接# https://register.gotowebinar.com/register/2823468241337063262 时间 北京时间 2025 年 5 月 15 日 星期四 下午 3:30 - 4:30 适宜…

Spring Boot中的拦截器!

每次用户请求到达Spring Boot服务端&#xff0c;你是否需要重复写日志、权限检查或请求格式化代码&#xff1f;这些繁琐的“前置后置”工作让人头疼&#xff01;好在&#xff0c;Spring Boot拦截器如同一道智能关卡&#xff0c;统一处理请求的横切逻辑&#xff0c;让代码优雅又…

三个线程 a、b、c 并发运行,b,c 需要 a 线程的数据如何解决

说明&#xff1a; 开发中经常会碰到线程并发&#xff0c;但是后续线程需要等待第一个线程执行完返回结果后&#xff0c;才能再执行后面线程。 如何处理呢&#xff0c;今天就介绍两种方法 1、使用Java自有的API即CountDownLatch&#xff0c;进行实现 思考&#xff1a;CountDown…

js原型污染 + xss劫持base -- no-code b01lersctf 2025

题目信息:Found this new web framework the other day—you don’t need to write any code, just JSON. 我们先来搞清楚究竟发生了什么 当我们访问 /index /*** 处理 /:page 路径的 GET 请求* param {Object} req - 请求对象* param {Object} reply - 响应对象* returns {Pro…