QTableView 切换折叠展开图标

    这段时间对MVC的使用和个人理解,发现MVC更侧重显示数据,对于数据的修改之类的操作,实现起来比较繁琐. 那么如何在QTableView切换节点折叠展开的图标呢 

 

一. QTreeWidget下的实现

      连接信号itemExpanded ( QTreeWidgetItem * item ) 和itemCollapsed ( QTreeWidgetItem * item ), 然后操作设置该节点图标 item->setIcon(); 几行代码就搞定了

 

二. QTableView下的实现

   在MVC中修改数据, 必须发射 dataChanged(index,index) 来通知模型更新数据, 也就是必须重新实现 QAbstractItemModel::setData(index,value,role), 在该方法中发现更新信号 

   1. 连接节点折叠展开信号 

connect(this,SIGNAL(expanded(const QModelIndex &)),this,SLOT(expand(const QModelIndex &)));
connect(this,SIGNAL(collapsed(const QModelIndex &)),this,SLOT(collapse(const QModelIndex &)));

void TableView::expand(const QModelIndex &index)
{
    pModel->setData(index,true,Qt::DecorationRole);
}

void TableView::collapse(const QModelIndex &index)
{
    pModel->setData(index,false,Qt::DecorationRole);
}

 

   2. 重新实现 QAbstractItemModel::setData(),通知视图刷新 

bool TagTreeModel::setData(const QModelIndex &index, const QVariant &value, int role)
{
    if(index.isValid()&&role==Qt::DecorationRole)
    {
        bool pStatus=value.toBool();

	// 设置当前图标
        TreeItem *item=static_cast<TreeItem*>(index.internalPointer());
        item->setIcon(pStatus);

	// 发射dataChanged(index,index),确保视图刷新图标
	emit dataChanged(index,index);
        return true;
    }

    return false;
}

 

   效果如下:

   QTableView 切换折叠展开图标

 

 

你可能感兴趣的:(expand,icon,QTreeView,切换树形图标,collpase)