QTreeView 使用 QStandardItemModel
QTreeView 使用 QStandardItemModel
@
前言
Qt 模型视图的讲解到处都是,就不废话了。直接说QTreeView使用QsStandardItemModel的基本用法
一、直接上图

二、添加同级结点项
1.思路
1. 通过QTreeView的currentIndex()函数,获取当前结点的索引
2. 通过QStandardItemModel的itemFromIndex()函数,获取当前结点
3. 通过QStandardItem的parent()函数,获取当前结点的父结点
4. 用父结点添加一个新结点
2.实现
代码如下:
// 实例化一个要添加的结点
QStandardItem* item = new QStandardItem(QStringLiteral("新结点"));
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则直接添加顶级结点
if (!curIndex.isValid())
{
pModel->appendRow(item);
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果当前结点的父结点为空则是顶级结点
if (!parentItem) {
pModel->appendRow(item);
}
else {
parentItem->appendRow(item);
}
// 设置添加的结点为当前结点
ui.treeView->setCurrentIndex(item->index());
二、添加子结点项
1. 思路
1. 还是先获取当前结点的索引
2. 再获取当前结点
3. 当前结点直接添加一个子结点
2. 实现
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 实例化一个要添加的结点
QStandardItem* item = new QStandardItem(QStringLiteral("新结点"));
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 添加到子结点
curItem->appendRow(item);
// 设置添加的结点为当前结点
ui.treeView->setCurrentIndex(item->index());
三、结点项上移
1. 思路
1. 还是先获取当前结点的索引
2. 再获取当前结点
3. 判断如果当前结点已经是最上面一行了,则不做处理
4. 获取父结点
5. 父结点先移除当前结点,再把移除的结点添加到当前结点-1的位置
2.实现
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的行
int row = curItem->row();
// 如果当前结点是第0行则不做处理
if (row == 0)
{
return;
}
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果父结点无效,则当前结点是顶级结点
if (!parentItem)
{
// 用model直接操作
// 先移除当前结点,再添加到当前结点索引-1的位置
pModel->insertRow(row - 1, pModel->takeRow(row));
}
else
{
// 用父结点操作
parentItem->insertRow(row - 1, parentItem->takeRow(row));
}
// 设置当前结点
ui.treeView->setCurrentIndex(curItem->index());
四、结点项下移
1. 思路
1. 和结点上移思路一样,只不过重新添加的位置是+1
2.代码
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的行
int row = curItem->row();
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果父结点无效,则当前结点是顶级结点
if (!parentItem)
{
// 用model直接操作
// 如果当前结点是最后一行则不做处理
if (row == pModel->rowCount() - 1)
{
return;
}
// 先移除当前结点,再添加到当前结点索引-1的位置
pModel->insertRow(row + 1, pModel->takeRow(row));
}
else
{
// 如果当前结点是最后一行则不做处理
if (row == parentItem->rowCount() - 1)
{
return;
}
// 用父结点操作
parentItem->insertRow(row + 1, parentItem->takeRow(row));
}
// 设置当前结点
ui.treeView->setCurrentIndex(curItem->index());
五、结点升级
1. 思路
1. 还是先获取当前结点
2. 再获取当前结点的父结点
3. 再获取父结点的父结点
4. 将当前结点从父结点移除
5. 将移除的结点添加到父结点的父结点
2.代码
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的行
int row = curItem->row();
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果父结点无效,则当前结点是顶级结点,不能再升级了,不做处理
if (!parentItem)
{
return;
}
else
{
// 获取父结点的的父结点
auto parent = parentItem->parent();
// 如果父结点 的 父结点 无效 则父结点是顶级结点,直接用model操作
if (!parent)
{
// 从父结点移除,父结点的父结点添加(添加位置随意),当前结点则成为了原本父结点的兄弟结点
pModel->insertRow(parentItem->row(), parentItem->takeRow(curItem->row()));
}
else
{
parent->insertRow(parentItem->row(), parentItem->takeRow(curItem->row()));
}
// 设置当前结点
ui.treeView->setCurrentIndex(curItem->index());
}
五、结点降级
1. 思路
1. 获取当前结点
2. 获取当前结点兄弟结点
3. 将当前结点添加到兄弟结点
2.代码
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的行
int row = curItem->row();
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果父结点无效,则当前结点是顶级结点,不能再升级了,不做处理
if (!parentItem)
{
return;
}
else
{
// 获取父结点的的父结点
auto parent = parentItem->parent();
// 如果父结点 的 父结点 无效 则父结点是顶级结点,直接用model操作
if (!parent)
{
// 从父结点移除,父结点的父结点添加(添加位置随意),当前结点则成为了原本父结点的兄弟结点
pModel->insertRow(parentItem->row(), parentItem->takeRow(curItem->row()));
}
else
{
parent->insertRow(parentItem->row(), parentItem->takeRow(curItem->row()));
}
// 设置当前结点
ui.treeView->setCurrentIndex(curItem->index());
}
五、删除结点
1. 思路
1. 获取当前结点的父结点
2. 通过父结点删除当前结点
2.代码
代码如下:
// 当前结点的索引
auto curIndex = ui.treeView->currentIndex();
// 无效则不做处理
if (!curIndex.isValid())
{
return;
}
// 当前结点
auto curItem = pModel->itemFromIndex(curIndex);
// 当前结点的父结点
auto parentItem = curItem->parent();
// 如果父结点无效,则当前结点是顶级结点,直接使用model操作
if (!parentItem)
{
pModel->takeRow(curItem->row());
}
else
{
parentItem->takeRow(curItem->row());
}
总结
没有
QTreeView 使用 QStandardItemModel的更多相关文章
- 【转】Qt之模型/视图
[本文转自]http://blog.sina.com.cn/s/blog_a6fb6cc90101hh20.html 作者: 一去丶二三里 关于Qt中MVC的介绍与使用,助手中有一节模型/视图编程 ...
- 11.树形Model/View实例
任务1:显示如图的树形结构 思考: 1.使用QTreeView显示. 2.Model使用QStandardItemModel,qt的一个标准model. 3.QStandardItemModel下每一 ...
- qt 关于Qt中MVC的介绍与使用
Qt包含一组使用模型/视图结构的类,可以用来管理数据并呈现给用户.这种体系结构引入的分离使开发人员更灵活地定制项目,并且提供了一个标准模型的接口,以允许广泛范围的数据源被使用到到现有的视图中. 模型 ...
- Qt——树的搜索实现源码
一.使用QTreeWidget 头文件: /************************************************************************ 树的搜索类 ...
- C/C++ Qt TreeWidget 嵌套节点操作技巧
在上一篇博文<C/C++ Qt TreeWidget 单层树形组件应用>中给大家演示了如何使用TreeWidget组件创建单层树形结构,并给这个树形组件增加了右键菜单功能,接下来将继续延申 ...
- QStandardItemModel角色控制及QTreeView加入不同的右键菜单
1.概述 QTreeView最长用的一个功能就是作为导航栏,像vs里的项目结构树,word的文档结构图,资源管理器的文档结构,等等都是利用树形结构组织的,在前面已经讲述了Qt中使用标准化项目模型QSt ...
- QStandardItemModel角色控制及QTreeView添加不同的右键菜单
http://blog.csdn.net/czyt1988/article/details/26018513
- Qt树形控件QTreeView使用1——节点的添加删除操作 复选框的设置
QtreeView是ui中最常用的控件,Qt中QTreeWidget比QTreeView更简单,但没有QTreeView那么灵活(QTreeWidget封装的和MFC的CTreeCtrl很类似,没有m ...
- 关于QStandardItemModel
类QabstractItemModel,QabstractListModel,QAbstractTableModel不保存数据,用户需要从这些类派生出子类,并在子类中定义某种数据结构来保存数据.与此不 ...
随机推荐
- 2021年主流CRM系统盘点
面对市面上五花八门的CRM系统,相信您在选择的时候肯定是一头雾水.哪个CRM系统功能最强大?哪个CRM系统性价比最高?哪个CRM系统最适合企业使用?本篇文章小编将选出几家有代表性的CRM系统,并进行对 ...
- Vue | 指令实现自动翻译填充英文名功能
背景:应用系统中存在多个创建实体表单,表单填写时,在填写中文名称后,要填写对应的英文名作为标识或数据库查询索引. 需求:填写中文名的同时,系统自动生成英文名并填充到表单中,辅助用户操作,节约操作时间. ...
- redis中keys命令带来的线上性能问题
起因 下午接到运维反馈,生产redis有个执行keys的命令请求太慢了,要两三秒才能响应 涉及命令如下: KEYS ttl_600::findHeadFootData-15349232-*-head ...
- 019.Python函数sorted,filter和推导式
一 sorted函数 sorted(iterable,reverse=False,key=函数) 功能:排序 参数: iterable:可迭代性数据(常用:容器类型数据,range对象,迭代器) re ...
- Redis I/O 多路复用技术原理
引言 Redis 是一个单线程却性能非常好的内存数据库, 主要用来作为缓存系统. Redis 采用网络 I/O 多路复用技术来保证在多个连接时,系统的高吞吐量(TPS). 系统吞吐量(TPS)指的是系 ...
- UCOSII中的主栈扩展
听陈*均说 UCOSII源代码中有这样的机制 当某个TASK的栈不够用.访问越界时 会自动调用系统生成的备用扩展栈区 但这样也有风险 备用扩展栈区如果被击穿则会造成更大的错误,可能会导致程序跑飞,如果 ...
- 90%的人都不知道的Node.js 依赖关系管理(下)
转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文参考:https://dzone.com/articles/node-dependency-manage ...
- VirtualBox安装配置CentOS7(含网络连接配置)
最近需要用到CentOS7,特地在虚拟机上安装一遍,中间走了很多弯路,特地在此处进行记录 前置条件: 1.本地完成Oracle VM VirtualBox,我安装的是6.1版本 2.下载CentOS安 ...
- Python+Selenium - 定位策略
一个元素定位可能会在多个地方用到,用loc变量接收元素的定位方式和相对路径.使用时再拆包(*loc) loc = (定位方式,'定位方式对应的元素路径') =>元素定位方式及路径 driv ...
- java 全端开源 电商系统 springboot uniapp 小程序 前后端分离 高可用
Lilishop B2B2C商城系统 官方公众号 & 开源不易,如有帮助请点Star 所有jar包均可从maven中央仓库下载,无二次封装jar包,全端开源,无后门,无监控. 介绍 官网:ht ...