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. IP包头部格式解析

    IPv4首部一般是20字节长.在以太网帧中,IPv4包首部紧跟着以太网帧首部,同时以太网帧首部中的协议类型值设置为080016. IPv4提供不同,大部分是很少用的选项,使得IPv4包首部最长可扩展到 ...

  2. JAVA并发(1)-AQS(亿点细节)

    AQS(AbstractQueuedSynchronizer), 可以说的夸张点,并发包中的几乎所有类都是基于AQS的. 一起揭开AQS的面纱 1. 介绍 为依赖 FIFO阻塞队列 的阻塞锁和相关同步 ...

  3. java集合-哈希表HashTable

    一.简介 HashTable也是一种key-value结构,key-value不允许null,并且这个类的几乎全部的方法都加上了synchronized锁,来保证并发安全,由于加了锁所以性能方面会比较 ...

  4. spring总结归纳

    愿历尽千帆,归来仍是少年 简介 spring: 1.是分层的full-stack(全栈)轻量级开源框架.2. 内核:IOC和AOP.3.提供web层springMvc和业务层事务管理,整合众多的开源框 ...

  5. ArrayList方法源码分析

    本文将从ArrayList类的存储结构.初始化.增删数据.扩容处理以及元素迭代等几个方面,分析该类常用方法的源码. 数据存储设计 该类用一个Object类型的数组存储容器的元素.对于容量为空的情况,提 ...

  6. istioctl命令整理

    显示配置文件中的差异 istioctl profile diff default demo 显示对应配置的profile istioctl profile dump demo 显示可用的配置 isti ...

  7. 强哥ThinkPHP学习笔记

    TP框架:1.模板引擎2.MVC设计模式3.常用操作类 模板引擎和框架区别1.模板引擎只是框架中用来做php和html分离 MVC设计模式M model 数据模型V view 视图C control ...

  8. Spring5学习 (核心)

    Spring5 官方文档:https://docs.spring.io/spring/docs/5.3.0-SNAPSHOT/spring-framework-reference/index.html ...

  9. Linux进阶之使用Oh-My-Zsh打造炫酷终端

    Oh My Zsh是基于zsh命令行的一个扩展工具集,提供了丰富的扩展功能.除了功能增强之外,还提供非常丰富的主题.使用Oh-My-Zsh打造酷炫Shell终端的步骤(Deepin系统): 原始终端: ...

  10. https 真的安全吗,可以抓包吗,如何防止抓包吗

    Android_interview github 地址 大家好,我是程序员徐公,加上实习,有五年中大厂经验.自荐一下,可以关注我的微信公众号程序员徐公 公众号程序员徐公回复黑马,获取 Android ...