【QT5】 QTreeWidget树形视图的展开、收缩操作

  

           在使用树形控件实现项目分组功能时,默认情况下双击QTreeWidget的Item,如果该Item含有子Item那么Item就会被展开或收缩,而若是想要改变分组的展开及收缩状态,使用QTreeWidget的一个函数即可,void setItemsExpandable ( bool enable ), 该函数从QTreeView继承。设置是否允许用户展开和收缩Item。

           设置的itemsExpandable,默认是true。设置为false即不允许用户收缩/展开Item。若是要让Item始终保持展开,虽然不允许用户收缩/展开但是可以通过接口来使Item展开。调用QTreeWidgetItem的setExpanded。更快捷的方式就是调用QTreeWidget的expandAll()。

ui.treeWidget_trajectoryList->setItemsExpandable(true);

ui.treeWidget_trajectoryList->expandAll(); 
  • 单独(或一起)使用expandALL或设置itemsExpandable的属性为true,均可允许用户展开或收缩Item;
  • 使用expandALL,但同时设置itemsExpandable的属性为false,只允许用户展开Item;
  • 只设置itemsExpandable的属性为false,用户只可收缩Item,不允许展开。

测试代码如下:

(1)仅设置setItemsExpandable为false:

结果:组名无法展开其子Item,如下:

(2)设置setItemsExpandable为false,同时添加 expandALL;

结果:子Item只能保持展开状态,无法收缩,如下:

(3)仅设置setItemsExpandable为true:

结果:点击Item,子Item可自由展开或收缩,如下:

(4)设置setItemsExpandable为false,同时添加 expandALL;

结果:点击Item,子Item可自由展开、收缩,如下:

(5)仅添加expandALL:

结果:点击Item,子item可自由展开、收缩,如下:

  • 9
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt是一个跨平台的应用程序开发框架,它提供了丰富的组件和工具,用于快速构建现代化的图形用户界面。在Qt中,导航栏可以通过使用树形结构来实现。 树形结构是一种层级结构,常用于表示有父子关系的数据。在导航栏中,使用树形结构可以方便地组织和展示多级菜单或目录。 要实现一个基于树形结构的导航栏,我们可以使用Qt提供的一些相关类和组件。首先,我们可以使用QTreeView组件作为导航栏的主界面。QTreeView是一个用于显示树形结构的可视组件,它可以在其内部生成树形结构的视图。 接下来,我们需要定义一个数据模型来存储和管理树形结构的数据。在Qt中,常用的数据模型类是QStandardItemModel。QStandardItemModel是一个预定义的数据模型,可以用于管理带有父子关系的数据。我们可以通过添加QStandardItem来构建树形结构,并使用setItem方法设置父子关系。 在QTreeView中,我们可以使用setModel方法将QStandardItemModel设置为其数据模型,并使用expandAll方法展开所有节点。我们还可以使用QTreeView的一些信号和槽函数来实现节点的展开和折叠,以及与节点相关的操作。 总结起来,通过利用Qt中的QTreeView和QStandardItemModel,我们可以很方便地实现一个导航栏树形结构。我们可以根据需要添加和管理树形结构的节点,实现导航栏的功能。同时,Qt提供的丰富的UI组件和事件机制,也可以让我们进一步定制和优化导航栏的实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

&Mr.Gong

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值