Qt鼠标偏移之globalPos()以及pos()

globalPos()

event->globalPos()是事件发生时鼠标相对于我们整个屏幕的左上角(0,0)的偏移值
在这里插入图片描述

pos()

pos()是事件发生时鼠标相对于窗口的左上角(0,0)的偏移值
在这里插入图片描述

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现在Qt中长按图标按钮并使其跟随鼠标移动,并且实现双击按钮跳转界面,你可以按照以下步骤进行操作: 1. 创建一个自定义的按钮类,继承自`QPushButton`,并重写`mousePressEvent`、`mouseMoveEvent`、`mouseReleaseEvent`和`mouseDoubleClickEvent`方法。这些方法用于处理按钮的鼠标事件。 ```cpp class CustomButton : public QPushButton { public: CustomButton(QWidget *parent = nullptr) : QPushButton(parent) {} protected: void mousePressEvent(QMouseEvent *event) override; void mouseMoveEvent(QMouseEvent *event) override; void mouseReleaseEvent(QMouseEvent *event) override; void mouseDoubleClickEvent(QMouseEvent *event) override; }; ``` 2. 在 `mousePressEvent` 方法中,检查是否是鼠标左键按下,并记录当前鼠标位置和按钮的初始位置。 ```cpp void CustomButton::mousePressEvent(QMouseEvent *event) { if (event->button() == Qt::LeftButton) { // 记录当前鼠标位置和按钮的初始位置 m_dragStartPosition = event->globalPos(); m_buttonStartPosition = this->pos(); } } ``` 3. 在 `mouseMoveEvent` 方法中,计算鼠标移动的偏移量,并将按钮的位置更新为初始位置加上偏移量。 ```cpp void CustomButton::mouseMoveEvent(QMouseEvent *event) { if (event->buttons() & Qt::LeftButton) { // 计算鼠标移动的偏移量 QPoint offset = event->globalPos() - m_dragStartPosition; // 更新按钮的位置 this->move(m_buttonStartPosition + offset); } } ``` 4. 在 `mouseReleaseEvent` 方法中,检查鼠标是否释放。 ```cpp void CustomButton::mouseReleaseEvent(QMouseEvent *event) { if (event->button() == Qt::LeftButton) { // 执行按钮的默认行为 QPushButton::mouseReleaseEvent(event); } } ``` 5. 在 `mouseDoubleClickEvent` 方法中,检查是否是鼠标双击事件,并在双击时执行跳转界面的操作。 ```cpp void CustomButton::mouseDoubleClickEvent(QMouseEvent *event) { if (event->button() == Qt::LeftButton) { // 执行跳转界面的操作 // 这里可以根据需要进行界面跳转的处理 // 例如:使用QStackedWidget切换到另一个界面 } } ``` 6. 在你的窗口中使用自定义按钮类。 ```cpp CustomButton *button = new CustomButton(this); button->setIcon(QIcon("path/to/your/icon.png")); button->setFixedSize(50, 50); button->setStyleSheet("QPushButton { border: none; }"); button->setCursor(Qt::PointingHandCursor); button->setToolTip("Drag me and double click to jump!"); button->show(); ``` 通过以上步骤,你创建了一个可以长按并跟随鼠标移动的图标按钮,并且实现了双击按钮跳转界面的功能。当你长按按钮并移动鼠标时,按钮会跟随鼠标移动;双击按钮时,会执行跳转界面的操作。 请注意,你需要将按钮放置在一个窗口或其他容器中,并确保启用了鼠标跟踪功能。你还可以根据需要自定义按钮的外观和行为。 希望这能帮助到你!如果有任何进一步的问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值