QT之TreeView节点拖动

话不多说,先上图
在这里插入图片描述
在自定义model中实现dropMimeData、supportedDropActions、mimeData三个函数。

virtual bool dropMimeData(const QMimeData *data, Qt::DropAction action, int row, int column, const QModelIndex &parent) override;
Qt::DropActions supportedDropActions() const override;
virtual QMimeData *mimeData(const QModelIndexList &indexes) const override;
bool TreeModel::dropMimeData(const QMimeData * data, Qt::DropAction action, int row, int column, const QModelIndex & parent)
{
	QByteArray array = data->data(QString("hehe"));
	QDataStream stream(&array, QIODevice::ReadOnly);
	qint64 p;
	stream >> p;
	QModelIndex* index = (QModelIndex*)p;

	TreeItem* item = static_cast<TreeItem*>(index->internalPointer());
	TreeItem* ParentItem = static_cast<TreeItem*>(parent.internalPointer());

	beginMoveRows(index->parent(), index->row(), index->row(), parent, ParentItem->childRows());
	item->ParentItem()->RemoveItem(item->row());
	ParentItem->AddChild(item);
	endMoveRows();

	delete index;

	return false;
}

Qt::DropActions TreeModel::supportedDropActions() const
{
	return Qt::MoveAction;
}

QMimeData * TreeModel::mimeData(const QModelIndexList & indexes) const
{
	QMimeData* mimeData = QAbstractItemModel::mimeData(indexes);
	//只取第一个
	for (int i = 0; i < indexes.count(); i++)
	{
		QModelIndex index = indexes[i];
		QModelIndex* p = new QModelIndex(index);
		TreeItem* item = static_cast<TreeItem*>(index.internalPointer());
		qDebug() << item->data(Qt::DisplayRole).toString();

		QByteArray array;
		QDataStream stream(&array, QIODevice::WriteOnly);
		stream << (qint64)p;
		mimeData->setData(QString("hehe"), array);
		return mimeData;
	}
	return mimeData;
}

设置treeview可拖动以及拖动模式等

ui->treeView->setDragEnabled(true); //允许拖拽
ui->treeView->setDragDropMode(QAbstractItemView::InternalMove); //拖放模式为移动
ui->treeView->setDropIndicatorShown(true);  //显示拖放位置

也可以在设计师里进行勾选
在这里插入图片描述
源代码链接

  • 2
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
C#中的TreeView控件可以通过拖拽节点的方式来实现节点的移动和排序。在TreeView控件上启用节点拖拽功能需要设置AllowDrop属性为true,然后通过处理控件的DragEnter、DragOver和DragDrop事件来实现节点的拖拽。 具体实现步骤如下: 1. 设置TreeView控件的AllowDrop属性为true,启用拖拽功能。 2. 处理TreeView控件的DragEnter事件,在该事件中设置允许拖拽的效果。 3. 处理TreeView控件的DragOver事件,在该事件中实现节点拖拽时的效果。 4. 处理TreeView控件的DragDrop事件,在该事件中实现节点拖拽完成后的效果。 以下是一个简单的实现代码示例: ``` private void treeView1_DragEnter(object sender, DragEventArgs e) { e.Effect = DragDropEffects.Move; } private void treeView1_DragOver(object sender, DragEventArgs e) { Point targetPoint = treeView1.PointToClient(new Point(e.X, e.Y)); TreeNode targetNode = treeView1.GetNodeAt(targetPoint); if (targetNode != null) { TreeNode draggedNode = (TreeNode)e.Data.GetData(typeof(TreeNode)); if (!draggedNode.Equals(targetNode) && !ContainsNode(draggedNode, targetNode)) { targetNode.BackColor = Color.LightGreen; e.Effect = DragDropEffects.Move; } else { e.Effect = DragDropEffects.None; } } } private void treeView1_DragDrop(object sender, DragEventArgs e) { Point targetPoint = treeView1.PointToClient(new Point(e.X, e.Y)); TreeNode targetNode = treeView1.GetNodeAt(targetPoint); TreeNode draggedNode = (TreeNode)e.Data.GetData(typeof(TreeNode)); if (targetNode != null && !draggedNode.Equals(targetNode) && !ContainsNode(draggedNode, targetNode)) { draggedNode.Remove(); targetNode.Nodes.Add(draggedNode); targetNode.BackColor = Color.White; } } private bool ContainsNode(TreeNode node1, TreeNode node2) { if (node2.Parent == null) return false; if (node2.Parent.Equals(node1)) return true; return ContainsNode(node1, node2.Parent); } ``` 注意:以上代码仅提供参考,实际使用中还需要根据具体需求进行适当的调整和扩展。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值