捕捉鼠标离开对话框事件

捕捉鼠标离开对话框事件

 

方法一

捕捉鼠标的进入事件比较容易捕捉, 就是在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);

}

 

用定时器不爽的话, 可以自己创建一个线程, 我觉得方法二方法也很好.

 

 

展开阅读全文

没有更多推荐了,返回首页