QTreeWidget Item懒加载

2023-11-09 04:20
文章标签 加载 item qtreewidget

本文主要是介绍QTreeWidget Item懒加载,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

qt界面加载,数据较多时是比较慢的,treeWidget加载数据,跟tableWidget类似思路,先加载部分。

QTreeWidget常用属性设置

    m_treeWidget->setColumnCount(1); //设置列数//m_treeWidget->headerItem()->setHidden(true);//隐藏表头m_treeWidget->header()->setDefaultSectionSize(20);//默认行高m_treeWidget->setMinimumWidth(200);//设置默认最小列宽m_treeWidget->setColumnWidth(0, 100);//设置第0列列宽//需加 #include <QStyleFactory>m_treeWidget->setStyle(QStyleFactory::create("windows"));//显示节点虚线 - +//m_treeWidget->header()->setSectionResizeMode(QHeaderView::Stretch);//设置列宽自动分均//m_treeWidget->setEditTriggers(QAbstractItemView::NoEditTriggers);//禁止编辑m_treeWidget->setSelectionBehavior(QAbstractItemView::SelectRows);//以行为单位选择m_treeWidget->header()->setStyleSheet("QHeaderView::section{background-color:rgb(216,226,236);}""border:0px solid rgb(254,254,254);");//设置表头背景色QStringList headList;headList << "表头0" <<"表头1";m_treeWidget->setHeaderLabels(headList);//设置表头//需加 #include <QHeaderView>m_treeWidget->header()->setDefaultAlignment(Qt::AlignRight | Qt::AlignVCenter);//表头默认局右m_treeWidget->headerItem()->setTextAlignment(0, Qt::AlignLeft | Qt::AlignVCenter);//表头0列居左

QTreeWidget源码

直接分享示例代码

.h文件

#ifndef MyTREEWIDGET_H
#define MyTREEWIDGET_H#include <QWidget>#include <QTreeWidget>
#include <QTreeWidgetItem>
#include <QMap>class MyTreeWidget:public QWidget
{
public:MyTreeWidget(QWidget* parent= nullptr);~MyTreeWidget();void InitTree();void LoadTreeData();void MakeData();QString GetStr();QTreeWidgetItem*  SetItemText(QTreeWidgetItem* item, QString str);protected:void showEvent(QShowEvent *event) override;void hideEvent(QHideEvent *event) override;
private:bool m_bShow;int m_itemShowCnt;QTreeWidget* m_treeWidget;QTreeWidgetItem* m_topItem_1;QTreeWidgetItem* m_topItem_2;QMap<QString,QStringList> m_map;
};#endif // MyTREEWIDGET_H

.cpp文件

#include "mytreewidget.h"
#include <QVBoxLayout>
#include <QScrollBar>
#include <QTime>
#include <QDebug>
#include <QHeaderView>
#include <QStyleFactory>
#include <QThread>
MyTreeWidget::MyTreeWidget(QWidget* parent):QWidget(parent)
{resize(200,500);qsrand(time(NULL));m_bShow = false;
}MyTreeWidget::~MyTreeWidget()
{}void MyTreeWidget::InitTree()
{QVBoxLayout* vbox =new QVBoxLayout;vbox->setMargin(0);m_treeWidget = new QTreeWidget(this);m_treeWidget->setColumnCount(1); //设置列数//m_treeWidget->headerItem()->setHidden(true);//隐藏表头m_treeWidget->header()->setDefaultSectionSize(20);//默认行高m_treeWidget->setMinimumWidth(200);//设置默认最小列宽m_treeWidget->setColumnWidth(0, 100);//设置第0列列宽//需加 #include <QStyleFactory>m_treeWidget->setStyle(QStyleFactory::create("windows"));//显示节点虚线 - +//m_treeWidget->header()->setSectionResizeMode(QHeaderView::Stretch);//设置列宽自动分均//m_treeWidget->setEditTriggers(QAbstractItemView::NoEditTriggers);//禁止编辑m_treeWidget->setSelectionBehavior(QAbstractItemView::SelectRows);//以行为单位选择
//    m_treeWidget->header()->setStyleSheet(
//                "QHeaderView::section{background-color:rgb(216,226,236);}"
//                "border:0px solid rgb(254,254,254);");//设置表头背景色QStringList headList;headList << "表头0" <<"表头1";m_treeWidget->setHeaderLabels(headList);//设置表头//需加 #include <QHeaderView>m_treeWidget->header()->setDefaultAlignment(Qt::AlignRight | Qt::AlignVCenter);//表头默认局右m_treeWidget->headerItem()->setTextAlignment(0, Qt::AlignLeft | Qt::AlignVCenter);//表头0列居左vbox->addWidget(m_treeWidget);setLayout(vbox);m_topItem_1 = new  QTreeWidgetItem(m_treeWidget);m_topItem_2 = new  QTreeWidgetItem(m_treeWidget);m_topItem_1->setText(0,"ProJect");m_topItem_2->setText(0,"TestCase");m_treeWidget->addTopLevelItem(m_topItem_1);m_treeWidget->addTopLevelItem(m_topItem_2);m_itemShowCnt = 30;//设置默认item加载数量//展开加载connect(m_treeWidget,&QTreeWidget::itemExpanded,this,[=](QTreeWidgetItem *item){if(item != m_topItem_1 && item != m_topItem_2 && item->childCount() == 1)//初次展开则加载{QMap<QString,QStringList>::iterator itor =  m_map.find(item->text(0));if(itor == m_map.end())return;QStringList strList = itor.value();for (int i=1;i!=strList.length(); i++)//从第0个已经加载{SetItemText(item, itor.value().at(i));}};});//折叠connect(m_treeWidget,&QTreeWidget::itemCollapsed,this,[=](QTreeWidgetItem *item){qDebug()<<"折叠";});//绑定滚动条,根据滚动条值改变来加载connect(m_treeWidget->verticalScrollBar(),&QScrollBar::valueChanged,[=](int value){int currentItemCnt = m_topItem_1->childCount();//已加载topItem数量//滚动条移动到底端且未加载完if(value == m_treeWidget->verticalScrollBar()->maximum() && currentItemCnt < m_map.size()){QMap<QString,QStringList>::iterator itor =  m_map.begin();for (int i=0; i<currentItemCnt; i++){if(itor == m_map.end())break;itor++;}for (int i=0;itor!=m_map.end(); itor++,i++){if(i > m_itemShowCnt)break;//每次滚动条滑到底时,再加载一些item数量QTreeWidgetItem*  item = SetItemText(m_topItem_1, itor.key());//默认先加载一个SetItemText(item, itor.value().at(0));//默认先加载一个}}});//线程加载数据QThread* thread = new QThread();connect(thread, &QThread::started, thread, [=]()mutable{qDebug()<<"started!";MakeData();thread->quit();}, Qt::DirectConnection);//这里要加 Qt::DirectConnection 在线程执行connect(thread, &QThread::finished, this, [=]()mutable{thread->wait();thread->deleteLater();qDebug()<<"finished!";LoadTreeData();});thread->start();
}void MyTreeWidget::MakeData()
{int topItem = 1000;int item = 1000;for (int i=0; i<topItem;i++){QStringList strList;for (int j=0; j<item;j++){strList.append(QString::number(j) + GetStr());}m_map.insert(QString::number(i) + GetStr(),strList);}qDebug()<<"MakeData:"<<m_map.size();
}void MyTreeWidget::LoadTreeData()
{QMap<QString,QStringList>::iterator itor =  m_map.begin();for (int i=0; itor != m_map.end(); itor++,i++) {if(i > m_itemShowCnt)break;//只加载默认item数量QTreeWidgetItem* item = SetItemText(m_topItem_1, itor.key());SetItemText(item, itor.value().at(0));}
}void MyTreeWidget::showEvent(QShowEvent *event)
{if(!m_bShow){InitTree();m_bShow = true;}
}void MyTreeWidget::hideEvent(QHideEvent *event)
{}QTreeWidgetItem*  MyTreeWidget::SetItemText(QTreeWidgetItem *item, QString str)
{QTreeWidgetItem* childItem = new QTreeWidgetItem;item->addChild(childItem);childItem->setText(0,str);return childItem;
}QString MyTreeWidget::GetStr()
{int length = rand()%15+5;const char ch[] = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";int size = sizeof(ch);char* str = new char[length + 1];int num = 0;int i;for (i = 0; i < length; ++i){num = rand() % (size - 1);str[i] = ch[num];}str[i] = '\0';QString res(str);//return res;return "《"+res+"》";
}

在这里插入图片描述

这篇关于QTreeWidget Item懒加载的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/373932

相关文章

spring-boot-starter-thymeleaf加载外部html文件方式

《spring-boot-starter-thymeleaf加载外部html文件方式》本文介绍了在SpringMVC中使用Thymeleaf模板引擎加载外部HTML文件的方法,以及在SpringBoo... 目录1.Thymeleaf介绍2.springboot使用thymeleaf2.1.引入spring

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

SpringBoot项目启动后自动加载系统配置的多种实现方式

《SpringBoot项目启动后自动加载系统配置的多种实现方式》:本文主要介绍SpringBoot项目启动后自动加载系统配置的多种实现方式,并通过代码示例讲解的非常详细,对大家的学习或工作有一定的... 目录1. 使用 CommandLineRunner实现方式:2. 使用 ApplicationRunne

SpringBoot项目删除Bean或者不加载Bean的问题解决

《SpringBoot项目删除Bean或者不加载Bean的问题解决》文章介绍了在SpringBoot项目中如何使用@ComponentScan注解和自定义过滤器实现不加载某些Bean的方法,本文通过实... 使用@ComponentScan注解中的@ComponentScan.Filter标记不加载。@C

springboot 加载本地jar到maven的实现方法

《springboot加载本地jar到maven的实现方法》如何在SpringBoot项目中加载本地jar到Maven本地仓库,使用Maven的install-file目标来实现,本文结合实例代码给... 在Spring Boothttp://www.chinasem.cn项目中,如果你想要加载一个本地的ja

最好用的WPF加载动画功能

《最好用的WPF加载动画功能》当开发应用程序时,提供良好的用户体验(UX)是至关重要的,加载动画作为一种有效的沟通工具,它不仅能告知用户系统正在工作,还能够通过视觉上的吸引力来增强整体用户体验,本文给... 目录前言需求分析高级用法综合案例总结最后前言当开发应用程序时,提供良好的用户体验(UX)是至关重要

MyBatis延迟加载的处理方案

《MyBatis延迟加载的处理方案》MyBatis支持延迟加载(LazyLoading),允许在需要数据时才从数据库加载,而不是在查询结果第一次返回时就立即加载所有数据,延迟加载的核心思想是,将关联对... 目录MyBATis如何处理延迟加载?延迟加载的原理1. 开启延迟加载2. 延迟加载的配置2.1 使用

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

使用WebP解决网站加载速度问题,这些细节你需要了解

说到网页的图片格式,大家最常想到的可能是JPEG、PNG,毕竟这些老牌格式陪伴我们这么多年。然而,近几年,有一个格式悄悄崭露头角,那就是WebP。很多人可能听说过,但到底它好在哪?你的网站或者项目是不是也应该用WebP呢?别着急,今天咱们就来好好聊聊WebP这个图片格式的前世今生,以及它值不值得你花时间去用。 为什么会有WebP? 你有没有遇到过这样的情况?网页加载特别慢,尤其是那