新浪微博
腾讯微博
会员列表
统计排行
基本信息
到访IP统计
管理团队
管理统计
在线会员
会员排行
版块排行
帖子排行
标签排行
帮助
下拉
用户名
电子邮箱
用户名
密 码
记住登录
登录
找回密码
注册
快捷通道
关闭
您还没有登录,快捷通道只有在登录后才能使用。
立即登录
还没有帐号? 赶紧
注册一个
首页
论坛
Qt下载
作品展
群组
个人中心
捐赠、管理与开发
邮件订阅
帖子
文章
日志
用户
版块
群组
帖子
搜索
QTCN开发网
>
Qt基础编程
>
困扰已久的问题,大家帮忙看看!~QTreeWidget的
发帖
回复
返回列表
新帖
5918
阅读
6
回复
困扰已久的问题,大家帮忙看看!~QTreeWidget的
[复制链接]
上一主题
下一主题
离线
huyaowu
UID:98802
注册时间
2010-06-05
最后登录
2017-09-14
在线时间
6小时
发帖
69
搜Ta的帖子
精华
0
金钱
690
威望
79
贡献值
0
好评度
69
访问TA的空间
加好友
用道具
新手上路
关闭
个人中心可以申请新版勋章哦
立即申请
知道了
加关注
发消息
只看楼主
倒序阅读
楼主
发表于: 2010-10-30
— 本帖被 XChinux 执行加亮操作(2010-10-31) —
我想通过读
数据库
将内容显示在QTreeWidget上
数据库内的内容是这样的:
lsh name highlsh
1 a 0
2 b 1
3 c 1
4 d 3
其中highlsh是父节点的lsh,0就是root节点,要显示成这样:
a
|---b
|---c
|----d
想了很久没想出好的方法,大家给个思路啊,不甚感激!
共
条评分
回复
举报
分享到
淘江湖
新浪
QQ微博
QQ空间
开心
人人
豆瓣
网易微博
百度
鲜果
白社会
飞信
离线
dbzhang800
UID:7394
注册时间
2006-06-03
最后登录
2024-05-29
在线时间
9894小时
发帖
5580
搜Ta的帖子
精华
2
金钱
56167
威望
5627
贡献值
20
好评度
5629
访问TA的空间
加好友
用道具
论坛版主
加关注
发消息
只看该作者
1楼
发表于: 2010-10-30
感觉你应该去选择QTreeView 而不是 QTreeWidget
共
条评分
回复
举报
离线
huyaowu
UID:98802
注册时间
2010-06-05
最后登录
2017-09-14
在线时间
6小时
发帖
69
搜Ta的帖子
精华
0
金钱
690
威望
79
贡献值
0
好评度
69
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
2楼
发表于: 2010-10-30
好的,谢谢
共
条评分
回复
举报
离线
huyaowu
UID:98802
注册时间
2010-06-05
最后登录
2017-09-14
在线时间
6小时
发帖
69
搜Ta的帖子
精华
0
金钱
690
威望
79
贡献值
0
好评度
69
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
3楼
发表于: 2010-10-30
回 1楼(dbzhang800) 的帖子
能不能给个思路啊,我还是想不出来啊
共
条评分
回复
举报
离线
langziyang
UID:101676
注册时间
2010-07-22
最后登录
2019-06-27
在线时间
26小时
发帖
50
搜Ta的帖子
精华
0
金钱
520
威望
61
贡献值
0
好评度
51
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
4楼
发表于: 2010-11-11
顶上同求这个问题
共
条评分
回复
举报
离线
咖啡猫大人
UID:107504
注册时间
2010-11-09
最后登录
2015-07-27
在线时间
49小时
发帖
36
搜Ta的帖子
精华
0
金钱
360
威望
46
贡献值
0
好评度
36
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
5楼
发表于: 2010-11-12
用哈希表, lsh做key, highlsh做值. ---> QHash<lsh, highlsh>
这样就可以了.
共
条评分
回复
举报
离线
lejcey
UID:37353
注册时间
2007-09-30
最后登录
2017-11-17
在线时间
37小时
发帖
70
搜Ta的帖子
精华
3
金钱
780
威望
77
贡献值
0
好评度
76
访问TA的空间
加好友
用道具
新手上路
加关注
发消息
只看该作者
6楼
发表于: 2010-11-14
给你一个我的实现,此段代码有内存泄露,需改进!
把tree中的数据变成可以放进数据库中的数据
复制代码
/*
id dept tree parent
0 root(0) null
|
1 +-- dept1(0) 0
| |
2 | +-- sub dept 1(0) 1
| |
3 | +-- sub dept 2(1) 1
| |
4 | +-- subsub dept1(0) 3
| |
5 | +-- subsub dept2(1) 3
|
6 +-- dept2(1) 0
|
7 +-- dept3(2) 0
|
...
*/
// 创建一个容纳拥有子孙的节点的迭代器堆栈
QStack <QTreeWidgetItemIterator *> nodeItStack;
QTreeWidgetItemIterator *it = new QTreeWidgetItemIterator(treeDept->topLevelItem(0));
QTreeWidgetItemIterator *it2;
quint16 id = 0;
quint16 parent = 0;
QStack <quint16> parentStack;
while(*(*it)){
// 第一次进入循环的时候,nodeItStack是空的,但id是0
if (nodeItStack.isEmpty() && id != 0)
break;
// 如果当前迭代器所指向的节点拥有子节点
if ((*(*it))->childCount() > 0){
qDebug() << id << parent << (*(*it))->text(0);
//parent = id;
// 将当前节点的迭代器压入堆栈(它拥有子节点)
nodeItStack.push(it);
parentStack.push(id);
// 将迭代器变为当前节点的第一个子节点,必须创建一个新的 it,
// 否则栈中保存的上一个父节点的的指针和当前节点的指针相同了
it = new QTreeWidgetItemIterator((*(*it))->child(0));
++id;
}
// 否则当前节点已经没有子节点了,那就输出
else{
// 弹出上一次压入堆栈的父节点,临时保存一下
it2 = nodeItStack.pop();
parent = parentStack.pop();
// 如果当前节点不是是上一个父节点的最后一个,重新将上一个父节点压入堆栈
// 否则就不再重新入栈了
if ((*(*it2))->childCount() - 1 != (*(*it2))->indexOfChild(*(*it))){
nodeItStack.push(it2);
parentStack.push(parent);
}
qDebug() << id << parent << (*(*it))->text(0);
++*it;
++id;
}
}
delete it;
delete it2;
共
条评分
回复
举报
发帖
回复
返回列表
http://www.qtcn.org/bbs
访问内容超出本站范围,不能确定是否安全
继续访问
取消访问
快速回复
限100 字节
您目前还是游客,请
登录
或
注册
进入高级模式
文字颜色
发 布
回复后跳转到最后一页
上一个
下一个
关闭
补充发布信息
验证码:
发 布
隐藏
快速跳转
站务及资讯
网站公告
新闻资讯
Qt官方发布
网站管理
Qt应用及资源
Qt 作品展
Qt代码秀
Qt应用版
Qt技术讨论区
Qt安装与发布
Qt中文处理
Qt基础编程
Qt QML开发
Qt嵌入式开发
Qt移动平台开发
其它技术开发讨论区
Qt图书专区
《C++ GUI Qt 4编程》(第2版)专栏
《Qt高级编程》专栏
《零基础学Qt4编程》专栏
《Qt设计模式》(第2版) 图书专栏
Python Qt GUI快速编程
Qt项目开发区
天池项目
Qt开放平台开发库
机械CAD
扇贝词典
非活跃项目区
社区中心
帖子回收站(Trash)
招聘、求职、供求、广告等
休闲娱乐
关闭
关闭
选中
1
篇
全选