QDrag

一、描述

1、拖放是用户在应用程序中复制或移动数据的一种直观方式,并且在许多桌面环境中用作在应用程序之间复制数据的机制。

2、Qt中的拖放支持以QDrag类为中心,此类处理拖放操作的大多数细节。

3、通过拖放操作要传输的数据包含在QMimeData对象中。 通过setMimeData()指定:

     QDrag *drag = new QDrag(this);
     QMimeData *mimeData = new QMimeData;

     mimeData->setText(commentEdit->toPlainText());
     drag->setMimeData(mimeData);

4、setMimeData()将QMimeData对象的所有权分配给QDrag对象。必须在具有父QObject的堆上构造QDrag,以确保Qt在完成拖放操作后可以清理。

5、可以使用source()和target()找到源和目标小部件。这些功能通常用于确定拖放操作是否在同一窗口小部件上开始和结束,以便可以实现特殊行为。

二、信号

1、void actionChanged(Qt::DropAction action)

当对象的放下动作被改变时会发出此信号。

    QDrag *drag = new QDrag(this);
    drag->setMimeData(mimeData);
    connect(drag,&QDrag::actionChanged,[this]
    {
        qDebug()<<"emited QDrag::actionChanged";
    });
void Form::dragMoveEvent(QDragMoveEvent *event)
{
    if(event->pos().manhattanLength() > 500)
        event->setDropAction(Qt::IgnoreAction);
}

 拖动距离>500则忽略拖拽动作,效果:

2、void targetChanged(QObject *newTarget)

放下的目标改变时发出此信号。

    connect(drag,&QDrag::targetChanged,this,[]
    {
        qDebug()<<"emitid QDrag::targetChanged";
    });

 效果:

二、实用成员函数

1、[static] void cancel()

取消拖放操作。

2、Qt::DropAction exec(Qt::DropActions supportedActions = Qt::MoveAction)

开始拖放操作,并在完成时返回指示所请求的放置动作的值。 用户可以从中选择的放置动作在supportedActions中指定。 将按照以下顺序在允许的操作中选择默认的建议操作:移动,复制和链接。

3、Qt::DropAction exec(Qt::DropActions supportedActions, Qt::DropAction defaultDropAction)

同上,参数2是默认放下动作。

4、void setPixmap(const QPixmap &pixmap) / QPixmap pixmap()

设置/获取拖动过程中表示数据的图片。

    QDrag *drag = new QDrag(this);
    drag->setMimeData(mimeData);
    drag->setPixmap(QPixmap(":/woodbackground.png"));

5、void setHotSpot(const QPoint &hotspot) / QPoint hotSpot()

设置/获取拖动时pixmap()的图片和鼠标中心的相对位置。

例,设置鼠标居于图片中心点:

    QDrag *drag = new QDrag(this);
    drag->setMimeData(mimeData);
    auto pixmap = QPixmap(":/woodbackground.png");
    drag->setPixmap(pixmap);
    drag->setHotSpot(QPoint(pixmap.width()/2,pixmap.height()/2));

6、void setDragCursor(const QPixmap &cursor, Qt::DropAction action) / QPixmap dragCursor(Qt::DropAction action)

设置/获取拖放动作的光标。

    QDrag *drag = new QDrag(this);
    drag->setMimeData(mimeData);
    auto pixmap = QPixmap(":/woodbackground.png");
    drag->setPixmap(pixmap);
    drag->setDragCursor(QPixmap(":/a.png"),Qt::MoveAction);
    drag->setHotSpot(QPoint(pixmap.width()/2,pixmap.height()/2));

7、QObject *source() / QObject *target()

拖放的源对象/目标对象,指的是窗口而不是其中的子控件。

8、QMimeData *mimeData() / void setMimeData(QMimeData *data)

设置/获取mime对象,见:QMimeData详解

### 回答1: QDragQt框架中用于实现拖拽操作的类。当我们需要在两个见面之间拖拽时,可以通过以下步骤使用QDrag: 1. 首先,我们需要在QObject派生出的类中重写mousePressEvent事件。在该事件中,我们需要创建QDrag对象,并设置其相关属性。例如,我们可以使用setMimeData方法设置拖动的数据类型,使用setPixmap方法设置拖动时显示的图标。 2. 接下来,在mousePressEvent事件中,我们还需要调用exec方法开始拖拽操作。exec方法将启动一个事件循环,直到拖拽结束为止。我们可以在exec方法中设置拖拽操作的行为,例如设置Qt::MoveAction,表示移动操作(即拖拽源上的内容将被移动到目标位置)。 3. 当拖拽操作结束时,会触发dragLeaveEvent事件和dropEvent事件。我们可以在这两个事件中分别处理拖拽离开和放下的操作。例如,在dropEvent事件中,我们可以进行一些数据处理的操作,将拖拽源中的数据传输到目标位置。 总的来说,使用QDrag实现在两个见面之间的拖拽操作,我们需要重写mousePressEvent事件,创建并设置QDrag对象的相关属性,调用exec方法开始拖拽操作,并在dragLeaveEvent事件和dropEvent事件中处理拖拽离开和放下的操作。这样,我们就可以实现在Qt项目中两个见面之间的简单拖拽操作。 ### 回答2: Qt是一个跨平台的GUI开发框架,其中提供了丰富的控件和功能供开发者使用。QDragQt中的一个类,我们可以通过使用它来实现拖拽操作。 首先,我们需要在界面上创建两个控件,一个是源控件,一个是目标控件。接着,我们可以通过给源控件添加鼠标事件来实现拖拽操作。 当鼠标按下时,我们可以将源控件作为拖拽操作的起始点,同时创建一个QDrag对象。然后,我们通过将一些数据(例如文本信息或文件路径)与QDrag对象关联起来,使得在拖拽操作中可以传递这些数据。 接着,我们可以通过调用QDrag对象的exec()函数开始拖拽操作。在拖拽过程中,我们可以根据鼠标的位置更新目标控件的状态。当鼠标释放时,我们可以根据拖拽的结果来进行相应的操作。 需要注意的是,为了使得目标控件能够接受拖拽的数据,我们还需要在目标控件中实现相关的事件处理函数。例如,在目标控件中的dragEnterEvent()函数中,我们可以指定当拖拽进入目标控件时的一些表现,例如改变鼠标的样式或者显示一些提示信息。 总结起来,通过使用Qt中的QDrag类,我们可以很方便地实现拖拽操作。只需要在源控件中实现鼠标事件并与QDrag对象关联,然后在目标控件中实现拖拽事件的处理即可。这样,我们就可以在Qt中灵活地处理拖拽操作,提升用户的交互体验。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值