QTreeWidget设计解决没有拖动项问题

移动开发
设置QTreeWidget的dragDropMode为InternalMove,然后拖动项,希望把dropped的项设为current。但是发现Qt里竟然没有直接可用的方法或者signal可以得到这些信息。本文告诉您运用一些小技巧来实现QTreeWidget设计解决没有拖动项问题。

前不久诺基亚发布了Qt 4.7,新版本的Qt包括了全新的QML技术:一个先进的描述性编程语言,以及对于性能的提升。最近总有人提了这个问题:设置QTreeWidget的dragDropMode为InternalMove,然后拖动项,希望把dropped的项设为current。个人认为这是个比较基本的需求,但研究了一下,发现Qt里竟然没有直接可用的方法或者signal可以得到这些信息。进一步研究,实现是可以实现的,有点小繁琐,这里列出来,希望对其他Qt开发者有所帮助。

在你拖拽item的时候首先需要选中item, 所以我们可以通过响应currentItemChanged信号得到被拖动的项。 当然事情没那么简单。因为currentItemChanged的信号不光是拖拽的时候会发出, 还有可能是普通的鼠标点击也会触发这个信号,而且单从参数的内容或者用简单的API是区分不出这两种情况的。

为了判断这个信号是不是在拖拽期间发生的,可以重写 dropEvent虚函数。在拖拽发生时,currentItemChanged的信号是在dropEvent处理过程中发出。所以我们可以在进入dropEvent时设置一个flag, 函数结束时重置该flag。 然后在currentItemChanged的槽里根据flag的值确定拖拽动作是否发生, 进而参数中的prev就是我们需要的被拖动的项。

相关的代码列举重要部分如下:

  1. tw = new TreeWidget(this, 10,2); // customized treewidget class  
  2. tw->setDragDropMode(QAbstractItemView::InternalMove);//drag drop  
  3. connect(tw, SIGNAL(currentItemChanged(QTreeWidgetItem*, QTreeWidgetItem*)), this, SLOT(doCurrentItemChanged(QTreeWidgetItem*, QTreeWidgetItem*)));  
  4.  
  5.  
  6. void TreeWidget::dropEvent(QDropEvent*event)  
  7. {  
  8. qWarning() << "begin drop event....";//在这里设置标志  
  9. QTreeWidget::dropEvent(event);  
  10. qWarning() << "end drop event....";//在这里重置标志  
  11. }  
  12.  
  13.  
  14. void MainWin::doCurrentItemChanged(QTreeWidgetItem* cur, QTreeWidgetItem* prev)  
  15. {  
  16. if( prev)//在这里判断标志, prev即是被拖拽的项  
  17. qWarning() << "previous:" << prev->text(0);  
  18. }  

【编辑推荐】

  1. 诺基亚发布开发框架Qt4.7 推出快速UI工具
  2. 在QT SDK下构建MeeGo Touch开发环境
  3. 在Symbian应用程序Widget开发使用Qt加载和缩放图片
  4. QtCreator:MeeGo开发程序入门手册
责任编辑:佚名 来源: cuteqt
相关推荐

2009-06-06 19:07:44

java压缩文件

2024-08-08 08:19:03

2022-09-19 06:25:14

设计模式GoF

2019-03-15 11:07:35

华为云

2010-09-28 08:49:36

Java移动开发

2024-04-29 08:58:44

2010-04-20 11:08:33

Unix操作系统

2012-09-06 16:17:09

Ubuntu 12.0Windows 7

2017-03-28 13:21:50

互联网

2009-07-23 16:40:02

ASP.NET在线客服

2011-05-12 13:34:57

SQL Server

2023-01-04 10:24:42

2010-09-07 09:50:35

DIVCSS

2022-12-27 08:43:18

系统思维设计思维创新

2010-08-17 11:35:46

DIV CSS

2018-10-31 14:36:37

无人驾驶卡尔索普交通

2022-09-02 16:07:02

团队问题

2019-08-29 10:41:26

物联网数据网络

2018-12-18 10:23:45

Python代码内存

2011-05-19 14:16:29

网页设计
点赞
收藏

51CTO技术栈公众号