您的位置:首页 > 编程语言 > Qt开发

Qt Model/View之实现Item自定义显示

2017-06-05 10:58 2066 查看

介绍

Delegate 代理类被用来显示和编辑Item项。为了能实现自定义的Item,需要子类化代理类,并实现自己的paint() 和 sizeHint()方法。paint()方法会被每个Item调用,来绘制自定义的样式和相应的数据类型,sizeHint()方法用于指示每个Item的大小。在重绘Item在View中的显示时,QStyle类提供了很多的细节样式。

在Qt4.4以后,有两个代理类QItemDelegate和QStyleItemDelegate继承自QAbstractItemDelegate,缺省的代理是QStyleItemDelegate,这两个类是相互独立的两个类,都用来显示和编辑Item项。这两个类之前不同之处在于,QStyleItemDelegate使用当前样式绘制Item,因此建议当自定义代理或者使用Qt样式表时,将QStyleItemDelegate作为子类的基类来使用。除非自定义代理需要使用样式来绘制,否则他们两个类所需要的代码应该是一样的。

本文主要使用子类化代理,实现了TreeView中Item的自定义显示。

demo概述

废话不多说,先看效果图,如果想实现这类的数据显示,那么,这篇文章的demo会对你有所启发。







本demo主要的背景:有一些不同类型的设备,每个类型下又有若干节点。想要实现这种结构的数据的展示,并能支持某一类的全选,选中部分,同时使用checkbox显示三态(全选,选中部分,未选中)。

数据模型和视图

m_treeview_model = new QStandardItemModel(this);    //使用通用数据模型
m_treeview_model->clear();

ui->treeView->setModel(m_treeview_model);       //为TreeView设置数据模型
ui->treeView->setHeaderHidden(true);            //不显示表头
ui->treeView->setIndentation(0);                //Item的缩进为0
ui->treeView->setEditTriggers(QAbstractItemView::NoEditTriggers);   //不支持Item的编辑
ui->treeView->setItemDelegate(new customtreeViewDelegate(this)); //设置自定义代理,用于自定义Item的显示
ui->treeView->setExpandsOnDoubleClick(false);  //设置不允许双击Item时扩展该Item的子Item


自定义代理中paint()和sizeHint()方法的实现

//指示主Item项和childItem项的高度
QSize customtreeViewDelegate::sizeHint(const QStyleOptionViewItem &option, const QModelIndex &index) const{
if(!index.parent().isValid())    //mainItem
return QSize(option.rect.width(), 30);
else
return QSize(option.rect.width(), 40);
}


//绘制mianItem的checkbox
auto data = model->data(index, Qt::CheckStateRole);
QStyleOptionButton checkBoxStyle;
if(data == Qt::Unchecked)
{
checkBoxStyle.state |= QStyle::State_Off;
}
else if(data == Qt::PartiallyChecked)
{
checkBoxStyle.state |= QStyle::State_NoChange;
}
else if(data == Qt::Checked)
{
checkBoxStyle.state |= QStyle::State_On;
}
checkBoxStyle.state |= QStyle::State_Enabled;
checkBoxStyle.iconSize = QSize(20, 20);
checkBoxStyle.rect = QRect(QPoint(option.rect.right()-30,option.rect.top()+5),
QPoint(option.rect.right()-10,option.rect.bottom()-5));

QApplication::style()->drawPrimitive(QStyle::PE_IndicatorCheckBox, &checkBoxStyle, painter);


结语

自定义代理的paint()的实现,可以使用painter绘制任意的自定义Item,除了Text,可以是图片,其他多边形等等。

之前有篇文章讲述了代理对Item的编辑功能,至此,代理对Item的展示和编辑都已经实现。对Item的编辑的介绍,可以查看文章http://blog.csdn.net/sxpsxp12/article/details/52402496

一如既往,提供了demo源码,欢迎下载。源码环境Qt5.6.2+MSVC2015测试通过。 http://download.csdn.net/detail/sxpsxp12/9860900
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
相关文章推荐