1、要想实现mouseMoveEvent,则需要在构造函数中添加setMouseTrack(true),直接得到监听事件。若是setMouseTrack(false),只有鼠标按下才会有mouseMove监听事件响应。
2、使用setMouseTracking(true)对鼠标进行监控(mouseMoveEvent(QMouseEvent *event)),如果WidgetA有个子窗体WidgetB会占据WidgetA的绝大部分空间,那么当鼠标移动到WidgetB上时,WidgetA就会失去对鼠标的监控。
3、使用setAttribute( Qt::WA_Hover,true)也可以实现对鼠标的监控,相对于setMouseTracking(true)来说,它可以弥补鼠标事件被子窗体获取的问题:
bool Widget::event(QEvent *e)
{
if (e->type() == QEvent::HoverEnter || e->type() == QEvent::HoverLeave
|| e->type() == QEvent::HoverMove)
{
QHoverEvent* pHoverEvent = static_cast<QHoverEvent *>(e);
setMouseStatus(pHoverEvent->pos());
}
return QWidget::event(e);
}
本文介绍在Qt中如何通过setMouseTracking和setAttribute实现鼠标移动事件的监听。探讨了不同方法的优缺点,特别是在存在子窗体时如何保持父窗体对鼠标事件的监控。
444





