QTreeView 使用 QStandardItemModel

@

前言

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

一、直接上图

二、添加同级结点项

1.思路

1. 通过QTreeViewcurrentIndex()函数,获取当前结点的索引

2. 通过QStandardItemModelitemFromIndex()函数,获取当前结点

3. 通过QStandardItemparent()函数,获取当前结点的父结点

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的更多相关文章

  1. 【转】Qt之模型/视图

    [本文转自]http://blog.sina.com.cn/s/blog_a6fb6cc90101hh20.html   作者: 一去丶二三里 关于Qt中MVC的介绍与使用,助手中有一节模型/视图编程 ...

  2. 11.树形Model/View实例

    任务1:显示如图的树形结构 思考: 1.使用QTreeView显示. 2.Model使用QStandardItemModel,qt的一个标准model. 3.QStandardItemModel下每一 ...

  3. qt 关于Qt中MVC的介绍与使用

    Qt包含一组使用模型/视图结构的类,可以用来管理数据并呈现给用户.这种体系结构引入的分离使开发人员更灵活地定制项目,并且提供了一个标准模型的接口,以允许广泛范围的数据源被使用到到现有的视图中. 模型 ...

  4. Qt——树的搜索实现源码

    一.使用QTreeWidget 头文件: /************************************************************************ 树的搜索类 ...

  5. C/C++ Qt TreeWidget 嵌套节点操作技巧

    在上一篇博文<C/C++ Qt TreeWidget 单层树形组件应用>中给大家演示了如何使用TreeWidget组件创建单层树形结构,并给这个树形组件增加了右键菜单功能,接下来将继续延申 ...

  6. QStandardItemModel角色控制及QTreeView加入不同的右键菜单

    1.概述 QTreeView最长用的一个功能就是作为导航栏,像vs里的项目结构树,word的文档结构图,资源管理器的文档结构,等等都是利用树形结构组织的,在前面已经讲述了Qt中使用标准化项目模型QSt ...

  7. QStandardItemModel角色控制及QTreeView添加不同的右键菜单

    http://blog.csdn.net/czyt1988/article/details/26018513

  8. Qt树形控件QTreeView使用1——节点的添加删除操作 复选框的设置

    QtreeView是ui中最常用的控件,Qt中QTreeWidget比QTreeView更简单,但没有QTreeView那么灵活(QTreeWidget封装的和MFC的CTreeCtrl很类似,没有m ...

  9. 关于QStandardItemModel

    类QabstractItemModel,QabstractListModel,QAbstractTableModel不保存数据,用户需要从这些类派生出子类,并在子类中定义某种数据结构来保存数据.与此不 ...

随机推荐

  1. 2021年主流CRM系统盘点

    面对市面上五花八门的CRM系统,相信您在选择的时候肯定是一头雾水.哪个CRM系统功能最强大?哪个CRM系统性价比最高?哪个CRM系统最适合企业使用?本篇文章小编将选出几家有代表性的CRM系统,并进行对 ...

  2. Vue | 指令实现自动翻译填充英文名功能

    背景:应用系统中存在多个创建实体表单,表单填写时,在填写中文名称后,要填写对应的英文名作为标识或数据库查询索引. 需求:填写中文名的同时,系统自动生成英文名并填充到表单中,辅助用户操作,节约操作时间. ...

  3. redis中keys命令带来的线上性能问题

    起因 下午接到运维反馈,生产redis有个执行keys的命令请求太慢了,要两三秒才能响应 涉及命令如下: KEYS ttl_600::findHeadFootData-15349232-*-head ...

  4. 019.Python函数sorted,filter和推导式

    一 sorted函数 sorted(iterable,reverse=False,key=函数) 功能:排序 参数: iterable:可迭代性数据(常用:容器类型数据,range对象,迭代器) re ...

  5. Redis I/O 多路复用技术原理

    引言 Redis 是一个单线程却性能非常好的内存数据库, 主要用来作为缓存系统. Redis 采用网络 I/O 多路复用技术来保证在多个连接时,系统的高吞吐量(TPS). 系统吞吐量(TPS)指的是系 ...

  6. UCOSII中的主栈扩展

    听陈*均说 UCOSII源代码中有这样的机制 当某个TASK的栈不够用.访问越界时 会自动调用系统生成的备用扩展栈区 但这样也有风险 备用扩展栈区如果被击穿则会造成更大的错误,可能会导致程序跑飞,如果 ...

  7. 90%的人都不知道的Node.js 依赖关系管理(下)

    转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具.解决方案和服务,赋能开发者. 原文参考:https://dzone.com/articles/node-dependency-manage ...

  8. VirtualBox安装配置CentOS7(含网络连接配置)

    最近需要用到CentOS7,特地在虚拟机上安装一遍,中间走了很多弯路,特地在此处进行记录 前置条件: 1.本地完成Oracle VM VirtualBox,我安装的是6.1版本 2.下载CentOS安 ...

  9. Python+Selenium - 定位策略

    一个元素定位可能会在多个地方用到,用loc变量接收元素的定位方式和相对路径.使用时再拆包(*loc) loc = (定位方式,'定位方式对应的元素路径')    =>元素定位方式及路径 driv ...

  10. java 全端开源 电商系统 springboot uniapp 小程序 前后端分离 高可用

    Lilishop B2B2C商城系统 官方公众号 & 开源不易,如有帮助请点Star 所有jar包均可从maven中央仓库下载,无二次封装jar包,全端开源,无后门,无监控. 介绍 官网:ht ...