码迷,mamicode.com
首页 > 其他好文 > 详细

改变QTreeView项高的方法(改变Delegate行高,或者::data取数据的时候,根据Qt::SizeHintRole进行判断)

时间:2016-06-25 06:16:49      阅读:588      评论:0      收藏:0      [点我收藏+]

标签:

很久之前写过一篇关于QTreeView快速显示超过千万条数据项的方法,如果说那篇文章讲的是QTreeView的内功的话,今天这篇是讲QTreeView的外功,有时我们想改变视图的数据项的行高,那怎么办呢?今天在这里介绍两种改变行高的方法:

1.通过更改QTreeView的默认delegate的方法

 

[cpp] view plain copy
 
  1. class CDelegate : public QStyledItemDelegate  
  2. {  
  3.     Q_OBJECT  
  4. public:  
  5.     CDelegate(QObject *parent) : QStyledItemDelegate(parent)  
  6.     {  
  7.   
  8.     }  
  9. protected:  
  10.     QSize sizeHint(const QStyleOptionViewItem &option,  
  11.                                const QModelIndex &index) const  
  12.     {  
  13.         QSize size = QStyledItemDelegate::sizeHint(option, index);  
  14.         return QSize(size.width(), 28);  
  15.     }  
  16. };  

默认的情况下,QTreeView采用QStyledItemDelegate作为其代理,通过重载QStyledItemDelegate的sizeHint方法,我这里把行高设为28,大家可以根据需要修改对应的行高,然后,通过QTreeView的默认代理替换为CDelegate,我的做法如下:

 

 

[cpp] view plain copy
 
  1. CTreeView::CTreeView(QWidget *parent) : QTreeView(parent)  
  2. {  
  3.     CDelegate *pDelegate = new CDelegate(this);  
  4.     setItemDelegate(pDelegate);  
  5.     setUniformRowHeights(true);  
  6. }  

大家看是不是很简单

 

2.通过重载QAbstractItemModel的data方法,如下:

 

[cpp] view plain copy
 
  1. QVariant CMChModel::data(const QModelIndex &index, int role) const  
  2. {  
  3.     if (!index.isValid())  
  4.         return QVariant();  
  5.     if (Qt::SizeHintRole == role)  
  6.     {  
  7.         return QSize(pTreeView->visualRect(index).width(), 28);  
  8.     }  
  9.     return QVariant();  
  10. }  

 

其中pTreeView就是上面的CTreeView,这中方法不用在CTreeView构造函数中加:

 

[cpp] view plain copy
 
  1. CDelegate *pDelegate = new CDelegate(this);  
  2. setItemDelegate(pDelegate);  

 

是不是也很简单。

http://blog.csdn.net/rabinsong/article/details/13161799

改变QTreeView项高的方法(改变Delegate行高,或者::data取数据的时候,根据Qt::SizeHintRole进行判断)

标签:

原文地址:http://www.cnblogs.com/findumars/p/5615728.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!