Qt|QTreewidget类下函数qt助手详解说明示例(上)

news2024/11/21 0:20:10

该系列持续更新,喜欢请一键三连,感谢各位大佬。
QT5.14.2 参考官方QT助手

文章目录

  • QTreeWidget Class
  • properties
  • Public Functions
    • 默认构造函数
    • 默认析构函数
    • 添加根节点void addTopLevelItem(QTreeWidgetItem *item)
    • 添加多个根节点void addTopLevelItems(const QList<QTreeWidgetItem *> &items)
    • 关闭编辑void closePersistentEditor(QTreeWidgetItem *item, int column = 0)
    • 获取列数int columnCount() const
    • 返回当前选中列int currentColumn() const
    • 返回当前选中QTreeWidgetItem *currentItem() const
    • 没用void editItem(QTreeWidgetItem *item, int column = 0)
    • 查找满足条件的item返回QList<QTreeWidgetItem *> findItems(const QString &text, Qt::MatchFlags flags, int column = 0) const
    • 返回表头QTreeWidgetItem *headerItem() const
    • 返回index索引根据item int indexOfTopLevelItem(QTreeWidgetItem *item) const
    • 在指定索引位置插入新的top节点void insertTopLevelItem(int index, QTreeWidgetItem *item)
    • 插入多个top节点void insertTopLevelItems(int index, const QList<QTreeWidgetItem *> &items)
    • 递归访问所有根节点 返回一个模拟节点作为所有根节点的父节点QTreeWidgetItem *invisibleRootItem() const
    • 节点是否为可编辑状态bool isPersistentEditorOpen(QTreeWidgetItem *item, int column = 0) const
    • 不分层级获取上层相邻节点QTreeWidgetItem *itemAbove(const QTreeWidgetItem *item) const
    • 根据坐标返回节点QTreeWidgetItem *itemAt(const QPoint &p) const
    • 同上直接输入坐标QTreeWidgetItem *itemAt(int x, int y) const
    • 返回显示出的下层节点QTreeWidgetItem *itemBelow(const QTreeWidgetItem *item) const

在这里插入图片描述

QTreeWidget Class

The QTreeWidget class provides a tree view that uses a predefined tree model. More…
QTreeWidget类提供了一个使用预定义树模型的树视图。

Header:#include
qmake:QT += widgets
Inherits:QTreeView

List of all members, including inherited members
所有成员的列表,包括继承的成员
Obsolete members
过时的成员

properties

columnCount : int
topLevelItemCount : const int

Public Functions

默认构造函数

QTreeWidget::QTreeWidget(QWidget *parent = nullptr)
在这里插入图片描述
示例:

// 创建 QTreeWidget 对象
QTreeWidget *tree = new QTreeWidget;
tree->setColumnCount(3);                            // 设置列数为 3
tree->setHeaderLabels({ "Name", "Value", "Data" });   // 设置列标签
tree->header()->setSectionResizeMode(QHeaderView::ResizeToContents); // 自适应列宽

默认析构函数

QTreeWidget::~QTreeWidget()
在这里插入图片描述

添加根节点void addTopLevelItem(QTreeWidgetItem *item)

在这里插入图片描述
示例:

// 创建根节点
QTreeWidgetItem *root = new QTreeWidgetItem(tree);
root->setText(0, "Root");
root->setText(1, "0");
root->setData(2, Qt::UserRole, "root data");
tree->addTopLevelItem(root);

在这里插入图片描述

添加多个根节点void addTopLevelItems(const QList<QTreeWidgetItem *> &items)

在这里插入图片描述
示例:

// 创建根节点
QTreeWidgetItem *root = new QTreeWidgetItem(tree);
root->setText(0, "Root");
root->setText(1, "0");
root->setData(2, Qt::UserRole, "root data");
//tree->addTopLevelItem(root);
QList<QTreeWidgetItem* > all_root_list;
all_root_list.push_back(root);
QTreeWidgetItem *root1 = new QTreeWidgetItem(tree);
root1->setText(0, "Root2");
all_root_list.push_back(root1);
tree->addTopLevelItems(all_root_list);

在这里插入图片描述

关闭编辑void closePersistentEditor(QTreeWidgetItem *item, int column = 0)

在这里插入图片描述
关闭item编辑器,如果是关闭的则此函数无效。
先打开看效果是这样的:

tree->openPersistentEditor(root);

在这里插入图片描述
然后再调用closePersistentEditor

tree->openPersistentEditor(root);
tree->closePersistentEditor(root);

在这里插入图片描述

获取列数int columnCount() const

在这里插入图片描述

qDebug() << "tree->columnCount:"<<tree->columnCount();

在这里插入图片描述

返回当前选中列int currentColumn() const

在这里插入图片描述
默认-1,点击选中哪列返回列号,索引从0开始。

qDebug() << "tree->currentColumn:" << tree->currentColumn();
connect(tree, &QTreeWidget::itemClicked, this, [=] {
	qDebug() << "tree->currentColumn:" << tree->currentColumn();
});

在这里插入图片描述

返回当前选中QTreeWidgetItem *currentItem() const

在这里插入图片描述
默认是NULL

QTreeWidgetItem* selectItem = tree->currentItem();

在这里插入图片描述

没用void editItem(QTreeWidgetItem *item, int column = 0)

在这里插入图片描述

查找满足条件的item返回QList<QTreeWidgetItem *> findItems(const QString &text, Qt::MatchFlags flags, int column = 0) const

在这里插入图片描述
查找包含字符串ro的item,以字符串不分大小写匹配(第二个参数是匹配规则为枚举类型详见qt官方文档说明)

QList<QTreeWidgetItem*> find_items = tree->findItems("ro",Qt::MatchContains);
for (auto item:find_items)
{
	qDebug() << item->text(0);
}

在这里插入图片描述

返回表头QTreeWidgetItem *headerItem() const

在这里插入图片描述

QTreeWidgetItem* hearderItem = tree->headerItem();
qDebug() << hearderItem->text(0);
qDebug() << hearderItem->text(1);
qDebug() << hearderItem->text(2);
qDebug() << hearderItem->text(3);

在这里插入图片描述

返回index索引根据item int indexOfTopLevelItem(QTreeWidgetItem *item) const

在这里插入图片描述
只能获取到top节点索引

qDebug() << tree->indexOfTopLevelItem(nullptr);
qDebug() << tree->indexOfTopLevelItem(root);
qDebug() << tree->indexOfTopLevelItem(child2);
qDebug() << tree->indexOfTopLevelItem(root1);

在这里插入图片描述

在指定索引位置插入新的top节点void insertTopLevelItem(int index, QTreeWidgetItem *item)

在这里插入图片描述
插入qstring超过列数则不显示

QStringList insertitem;
insertitem << "insertroot" << "i2" << "2133" << "122344";
tree->insertTopLevelItem(1, new QTreeWidgetItem(insertitem));

在这里插入图片描述

插入多个top节点void insertTopLevelItems(int index, const QList<QTreeWidgetItem *> &items)

在这里插入图片描述

QStringList insertitem;
insertitem << "insertroot" << "i2" << "2133";
QList<QTreeWidgetItem*> qtree_widget_list;
qtree_widget_list.push_back(new QTreeWidgetItem(insertitem));
insertitem.clear();
insertitem << "insertroot2";
qtree_widget_list.push_back(new QTreeWidgetItem(insertitem));
tree->insertTopLevelItems(0, qtree_widget_list);

在这里插入图片描述

递归访问所有根节点 返回一个模拟节点作为所有根节点的父节点QTreeWidgetItem *invisibleRootItem() const

在这里插入图片描述
以该形式遍历所有根节点:

QTreeWidgetItem* one = tree->invisibleRootItem();
int nums = one->childCount();
for (int i=0;i<nums;++i)
{
	qDebug() << one->child(i)->text(0);
}

在这里插入图片描述

节点是否为可编辑状态bool isPersistentEditorOpen(QTreeWidgetItem *item, int column = 0) const

在这里插入图片描述
获取item是否为可编辑状态,qt5.10之后版本才有这个函数

qDebug()<< tree->isPersistentEditorOpen(root);
tree->openPersistentEditor(root);
qDebug() << tree->isPersistentEditorOpen(root);
tree->closePersistentEditor(root);
qDebug() << tree->isPersistentEditorOpen(root);

在这里插入图片描述

不分层级获取上层相邻节点QTreeWidgetItem *itemAbove(const QTreeWidgetItem *item) const

在这里插入图片描述
只能获取到展开节点,所以开始之前先调用expandAll(),否则获取到的为显示的相邻节点。
若没有显示出来的上层节点则返回空指针。

tree->expandAll();
QTreeWidgetItem* t1 = tree->itemAbove(root);
if (t1)
	qDebug() << t1->text(0);
t1 = tree->itemAbove(child1);
if (t1)
	qDebug() << t1->text(0);
t1 = tree->itemAbove(root1);
if (t1)
	qDebug() << t1->text(0);

在这里插入图片描述

根据坐标返回节点QTreeWidgetItem *itemAt(const QPoint &p) const

在这里插入图片描述
树形控件内部坐标,左上角为0,0点,如果对应坐标没有节点返回NULL

QPoint* p1 = new QPoint(0, 0);
QTreeWidgetItem* t1 = tree->itemAt(*p1);
if (t1)
	qDebug() << t1->text(0);
QPoint* p2 = new QPoint(0, 40);
t1 = tree->itemAt(*p2);
if (t1)
	qDebug() << t1->text(0);

在这里插入图片描述

同上直接输入坐标QTreeWidgetItem *itemAt(int x, int y) const

在这里插入图片描述
同上:
在这里插入图片描述

返回显示出的下层节点QTreeWidgetItem *itemBelow(const QTreeWidgetItem *item) const

在这里插入图片描述
同itemAbove,只是取得下层节点,没有下层则返回空指针
在这里插入图片描述

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

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

相关文章

Linux Shell脚本练习(一)

一、 Linux下执行Shell脚本的方式&#xff1a; 1、用shell程序执行脚本&#xff1a; a、根据你的shell脚本的类型&#xff0c;选择shell程序&#xff0c;常用的有sh&#xff0c;bash&#xff0c;tcsh等 b、程序的第一行#!/bin/bash里面指明了shell类型的&#xff0c;比如#!/…

linux查看服务器内核CUP版本相关命令

服务器参考 计算架构&#xff1a;x86-64产品系列&#xff1a;华为云耀云服务器操作系列&#xff1a;CentOS 7 执行uname -a查看服务器内核版本 Linux hecs-82210 3.10.0-1160.92.1.el7.x86_64 #1 SMP Tue Jun 20 11:48:01 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux执行hostn…

Aws Ec2服务器设置密码登录

通过密钥&#xff0c;ssh登录到服务器 切换到root sudo -i开始设置root的新密码 passwd root输入并确认新密码即可 5.修改ssh配置文件 vim /etc/ssh/sshd_config6.重启sshd配置 systemctl restart sshd

关于电脑一天24小时多少度电电脑的一天用电量计算

随着这几年物价的上涨&#xff0c;一些地区的电价越来越高&#xff0c;而我们经常需要使用电脑&#xff0c;那么一台电脑一天24小时用多少度电呢&#xff1f; 如何计算电脑一天的用电量&#xff1f; 让我们跟随小编来了解更多吧。 1、功耗、主机箱功耗 现在的计算机中&#xf…

2000-2022年上市公司绿色专利申请占比/数据

2000-2022年上市公司绿色专利申请占比数据 1、时间&#xff1a;2000-2022年 2、来源&#xff1a;国家知识产权局、WIPO绿色专利清单 3、指标&#xff1a;年份、股票代码、股票简称、行业代码、省份、城市、区县、行政区划代码、城市代码、区县代码、首次上市年份、上市状态、…

广和通发布基于MediaTek T300平台的RedCap模组FM330系列及解决方案

世界移动通信大会MWC 2024期间&#xff0c;广和通发布基于MediaTek T300平台的RedCap模组FM330系列&#xff0c;加速5G-A繁荣发展。FM330系列及其解决方案采用全球先进RedCap方案&#xff0c;满足移动宽带和工业互联对高能效的需求。 广和通FM330系列采用全球首款6nm制程且集成…

什么是回表、索引覆盖、索引下推【重点】

参考链接 【1】https://xiaolincoding.com/mysql/index/index_interview.html#%E6%8C%89%E6%95%B0%E6%8D%AE%E7%BB%93%E6%9E%84%E5%88%86%E7%B1%BB 【2】https://www.toutiao.com/article/7095749260137726476/?wid1709192807222 【3】https://zhuanlan.zhihu.com/p/401198674…

压缩式 交换式 碎片整理 :(使碎片减少或没有)

交换式碎片整理 首先流程 是 p3这个程序在运行&#xff0c;p1p2p4 的话在等待 &#xff0c;然后p3这时要多用3个内存块&#xff0c;这是 p4 通过拷贝&#xff0c;将内存拷贝到磁盘上&#xff0c;对应的数据也是从主存中cp到磁盘此时主存多出3个内存块给p3继续使用 2.压缩式碎片…

请求响应与统一响应结果

1.请求响应 1.安装postman 2.简单的参数 //原始的请求参数的方法RequestMapping("/simoleParam")public String simpleParam(HttpServletRequest request){String name request.getParameter("name");String ageStr request.getParameter("age&quo…

android开发书籍推荐,android面试复习

笼统来说&#xff0c;中年程序员容易被淘汰的原因其实不外乎三点。 1、输出能力已到顶点。这个人奋斗十来年了&#xff0c;依旧碌碌无为&#xff0c;很明显这人的天花板就这样了&#xff0c;说白了&#xff0c;天赋就这样。 2、适应能力越来越差。年纪大&#xff0c;有家庭&…

【Java】基本数据类型、包装类与字符串间的转换 例题

写在前面&#xff1a; 关于这道题&#xff0c;初见感觉有点cpu烧坏了&#xff0c;准确来说是看了网上的一些讲解都感觉不尽人意。自己整理了一下&#xff0c;希望能帮助到大家。 题目&#xff1a; 如下两个题目输出结果相同吗&#xff1f;各是什么。 Object o1 true ? new…

【web APIs】5、(学习笔记)有案例!

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、js组成window对象定时器-延迟函数location对象navigator对象histroy对象 二 、本地存储&#xff08;今日重点&#xff09;localStorage&#xff08;重点&am…

通过elementUI学习vue

<template><el-radio v-model"radio" label"1">备选项</el-radio><el-radio v-model"radio" label"2">备选项</el-radio> </template><script>export default {data () {return {radio: 1}…

[MYSQL数据库]--mysql的基础知识

前言 作者&#xff1a;小蜗牛向前冲 名言&#xff1a;我可以接受失败&#xff0c;但我不能接受放弃 如果觉的博主的文章还不错的话&#xff0c;还请点赞&#xff0c;收藏&#xff0c;关注&#x1f440;支持博主。如果发现有问题的地方欢迎❀大家在评论区指正 目录 一、数据库…

【力扣白嫖日记】550.游戏玩法分析IV

前言 练习sql语句&#xff0c;所有题目来自于力扣&#xff08;https://leetcode.cn/problemset/database/&#xff09;的免费数据库练习题。 今日题目&#xff1a; 550.游戏玩法分析IV 表&#xff1a;Activity 列名类型player_idintdevice_idintevent_datedategames_played…

分享:大数据信用报告查询的价格一般要多少钱?

现在很多人都开始了解自己的大数据信用了&#xff0c;纷纷去查大数据信用报告&#xff0c;由于大数据信用与人行征信有本质的区别&#xff0c;查询方式和价格都不是固定的&#xff0c;本文就为大家详细讲讲大数据信用报告查询的价格一般要多少钱&#xff0c;希望对你有帮助。 大…

v69.字符

1.字符类型 1.1 可以将char类型的变量赋值为整数&#xff0c;也可以赋值为字符! 注意字符要用单引号 ’ ’ 而不是双引号 每一个字符在计算机内部都有一个值去表达它。字符’1’ 在计算机里表示的十进制的整数值为49&#xff0c;就像’A’表示十进制值65。 1.2 scanf 与 p…

人工智能_大模型011_CPU微调_训练_显卡的选型讲解_价格表_011---人工智能工作笔记0146

既然CPU训练大模型无法实现那么就只能购置GPU显卡来进行训练了,来看看如何选型显卡. 之前是没有GPU的,由于游戏行业对画质的需求,催生出了GPU,GPU优势是支持并行计算,可以几千个小核心同时计算,但是有个问题,如何把一个我们需要计算的问题,拆解成1000个或更多小问题,让GPU并行…

【C++】AVL树详解

目录 一、AVL树的概念 二、AVL树节点的定义 三、AVL树的操作 3.1 AVL树的平衡因子 3.2 AVL树的插入 3.3 AVL树的旋转 3.4 AVL树的验证 四、AVL树的完整代码 上一篇已经对关联式容器set/map/multiset/multimap进行了简答的介绍&#xff0c;大家可能发现它们有一个共同点&…

Tomcat服务部署

1、安装jdk、设置环境变量并测试 第一步&#xff1a;安装jdk 在部署 Tomcat 之前必须安装好 jdk&#xff0c;因为 jdk 是 Tomcat 运行的必要环境。 1. #关闭防火墙 systemctl stop firewalld systemctl disable firewalld setenforce 02. #将安装 Tomcat 所需软件包传到/opt…