以下是一个简单的示例,演示如何使用 Qt 5.15 实现鼠标拖放事件:
#include <QtWidgets>
class DragWidget : public QLabel {
public:
explicit DragWidget(QWidget* parent = nullptr) : QLabel(parent) {
setPixmap(QPixmap("image.png"));
setAlignment(Qt::AlignCenter);
}
protected:
void mousePressEvent(QMouseEvent* event) override {
if (event->button() == Qt::LeftButton) {
m_dragStartPosition = event->pos();
}
}
void mouseMoveEvent(QMouseEvent* event) override {
if (!(event->buttons() & Qt::LeftButton)) return;
if ((event->pos() - m_dragStartPosition).manhattanLength()
< QApplication::startDragDistance()) {
return;
}
QDrag* drag = new QDrag(this);
QMimeData* mimeData = new QMimeData;
mimeData->setText("Hello, World!");
drag->setMimeData(mimeData);
QPixmap pixmap = *pixmap();
QPainter painter(&pixmap);
painter.setCompositionMode(QPainter::CompositionMode_DestinationIn);
painter.fillRect(pixmap.rect(), QColor(0, 0, 0, 127));
drag->setPixmap(pixmap);
drag->exec(Qt::CopyAction | Qt::MoveAction, Qt::CopyAction);
}
private:
QPoint m_dragStartPosition;
};
int main(int argc, char** argv) {
QApplication app(argc, argv);
DragWidget widget;
widget.setWindowTitle("Drag Widget");
widget.setGeometry(100, 100, 200, 200);
widget.setAcceptDrops(true);
widget.show();
return app.exec();
}
在这个例子中,我们创建了一个名为 DragWidget
的自定义 QLabel,它会显示一个图片,并且支持鼠标拖放操作。当用户按下左键时,程序记录下当前鼠标位置,作为拖动操作的起始点;当用户移动鼠标时,如果距离起始点超过一定距离(可以通过 QApplication::startDragDistance() 获取),则开始进行拖放操作。在 mouseMoveEvent()
方法中,我们使用 QDrag 类创建一个新的拖动对象,并将要传递给目标窗口的数据存储在 QMimeData 中。最后,我们设置了一个半透明的黑色遮罩来表示被拖动的图像,并调用 QDrag::exec()
方法开始执行拖放操作。
需要注意的是,在实现支持拖放功能的窗口或控件上,还需要重载其相应的 dragEnterEvent()、dragLeaveEvent() 和 dropEvent() 函数以响应与该窗口/控件交互的其他部分发送来的事件。这些函数的具体实现方式取决于你所使用 Qt 版本和具体需求。