捕捉鼠标离开对话框事件
方法一
捕捉鼠标的进入事件比较容易捕捉, 就是在WM_MOUSEMOVE中捕捉就可以了, 离开事件就比较麻烦, 看下面代码
// 在WM_MOUSEMOVE事件中
void CTestDesktopDlg::OnMouseMove(UINT nFlags, CPoint point)
{
// 增加这个 m_bTrack 是bool型, 初始化肯定是false了
if(!m_bTrack)
{
TRACKMOUSEEVENT tme;
tme.cbSize = sizeof(TRACKMOUSEEVENT);
tme.dwFlags = TME_HOVER | TME_LEAVE;
tme.dwHoverTime = HOVER_DEFAULT;
tme.hwndTrack = m_hWnd;
m_bTrack = _TrackMouseEvent(&tme);
}
CDialog::OnMouseMove(nFlags, point);
}
// 在这里响应
LRESULT CTestDesktopDlg::WindowProc(UINT message, WPARAM wParam, LPARAM lParam)
{
// TODO: 在此添加专用代码和/或调用基类
if(message == WM_MOUSELEAVE)
{
MessageBox(_T("鼠标离开"));
m_bTrack = false;
}
return CDialog::WindowProc(message, wParam, lParam);
}
该方法好像很好, 但有确定, 该方法的”鼠标离开”的定义是: 鼠标不在tme.hwndTrack = m_hWnd;窗口上, 但不是空间位置上, 只要m_hWnd失去焦点, 或者鼠标在m_hWnd的子窗口上, 也会触发WM_MOUSELEAVE消息, 而且每次离开后都要重新设置m_bTrack = _TrackMouseEvent(&tme);
方法二
BOOL CTestDesktopDlg::OnInitDialog()
{
CDialog::OnInitDialog();
//...
SetTimer(1, 100, NULL);
//...
}
void CTestDesktopDlg::OnTimer(UINT nIDEvent)
{
POINT pt;
::GetCursorPos(&pt);
CRect r;
GetWindowRect(&r);
if (r.PtInRect(pt))
{
TRACE("In dialog./r/n");
}
else
{
TRACE("Out of dialog./r/n");
}
CDialog::OnTimer(nIDEvent);
}
用定时器不爽的话, 可以自己创建一个线程, 我觉得方法二方法也很好.