线程中使用BeginWaitCursor();无效

DailyJob 2009-01-06 05:32:49
上次问过这个问题, 按照cnzdgs大哥指点, 在正常情况下是没有问题的.
但是如果在此期间我打开其它文件抢走焦点,鼠标在移动到程序上,鼠标就不是漏斗状了..

我想要实现当此线程运行时用户就不能再操作界面,线程结束后取消鼠标漏斗装,用户才能操作界面
有没有什么好办法,当线程执行时不管用户如何操作都不会影响鼠标漏斗状态?

DWORD __stdcall CGuardDataBackDlg::CopyMilkThread(LPVOID lParam)
{
WaitForSingleObject(hEvent, INFINITE);

CGuardDataBackDlg *pMainDlg = (CGuardDataBackDlg *)lParam;
::SendMessage(pMainDlg->m_hWnd,WM_CURSOR_STATE,1,0);
............//省略中间的操作..操作中有个弹出和关闭一个非模态对话框的操作.其它大部分为ado的数据库操作

::SendMessage(pMainDlg->m_hWnd,WM_CURSOR_STATE,0,0);
SetEvent(hEvent);
return 0;
}
LONG CGuardDataBackDlg::SetCursorState(WPARAM wParam, LPARAM lParam)
{
int nState = (int)wParam;
if(nState == 1)
{
m_bCurState = TRUE;
SetCapture();
BeginWaitCursor();
}
if(nState == 0)
{
m_bCurState = FALSE;
EndWaitCursor();
ReleaseCapture();
}
return 0;
}
...全文
429 12 打赏 收藏 转发到动态 举报
写回复
用AI写文章
12 条回复
切换为时间正序
请发表友善的回复…
发表回复
oyljerry 2009-01-06
  • 打赏
  • 举报
回复
[Quote=引用 9 楼 DailyJob 的回复:]
引用 3 楼 oyljerry 的回复:
进CopyMilkThread()的时候
就用CWaitCursor cr;

呵. 用CWaitCursor没有效果.
引用 4 楼 jimoguilai 的回复:
在对话框的WM_MOUSEMOVE里面
if(nState == 1)
{
m_bCurState = TRUE;
SetCapture();
BeginWaitCursor();
}
if(nState == 0)
{
m_bCurState = FALSE;
EndWaitCursor();
ReleaseCapture();
}

试试看可以不

试了下, 一样不行的
[/Quote]
那就进线程的时候,把UI禁用,然后退出线程的时候再Enable
DailyJob 2009-01-06
  • 打赏
  • 举报
回复
ok!
把SetCursorState里的代码搬到OnSetCursor里就成功了!
cnzdgs 2009-01-06
  • 打赏
  • 举报
回复
用EnableWindow把主窗口禁用就可以了。
DailyJob 2009-01-06
  • 打赏
  • 举报
回复
[Quote=引用 3 楼 oyljerry 的回复:]
进CopyMilkThread()的时候
就用CWaitCursor cr;
[/Quote]
呵. 用CWaitCursor没有效果.
[Quote=引用 4 楼 jimoguilai 的回复:]
在对话框的WM_MOUSEMOVE里面
if(nState == 1)
{
m_bCurState = TRUE;
SetCapture();
BeginWaitCursor();
}
if(nState == 0)
{
m_bCurState = FALSE;
EndWaitCursor();
ReleaseCapture();
}

试试看可以不
[/Quote]
试了下, 一样不行的
DailyJob 2009-01-06
  • 打赏
  • 举报
回复
确实可以.. 但这样的漏斗鼠标还是可以正常操作界面.
我最终的目的还是不让用户操作界面的
cnzdgs 2009-01-06
  • 打赏
  • 举报
回复
还有是否添加了ON_WM_SETCURSOR()消息宏?
cnzdgs 2009-01-06
  • 打赏
  • 举报
回复
你没处理对吧?是这样做的吗?
LONG CGuardDataBackDlg::SetCursorState(WPARAM wParam, LPARAM lParam)
{
m_Flag = (BOOL)wParam;
return 0;
}
DailyJob 2009-01-06
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 cnzdgs 的回复:]
这样好了,你定义一个标志变量BOOL m_Flag,初始化为FALSE,在SetCursorState中修改其值。另外响应WM_SETCURSOR消息,这样处理:

C/C++ codeBOOL CGuardDataBackDlg::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
{
if (m_Flag)
{
SetCursor(LoadCursor(NULL, IDC_WAIT));
return TRUE;
}

return CDialog::OnSetCursor(pWnd, nHitTest, message);
}
[/Quote]

还是一样会出现上面的情况, 比如程序现在是正常窗口, 我打开一其它(什么都可以)文件, 先最小化, 再最大化. 在最小化鼠标移动到程序界面上, 鼠标的漏斗状态就消失了.
Chivalry 2009-01-06
  • 打赏
  • 举报
回复
在对话框的WM_MOUSEMOVE里面
if(nState == 1)
{
m_bCurState = TRUE;
SetCapture();
BeginWaitCursor();
}
if(nState == 0)
{
m_bCurState = FALSE;
EndWaitCursor();
ReleaseCapture();
}

试试看可以不
oyljerry 2009-01-06
  • 打赏
  • 举报
回复
进CopyMilkThread()的时候
就用CWaitCursor cr;
cnzdgs 2009-01-06
  • 打赏
  • 举报
回复
这样好了,你定义一个标志变量BOOL m_Flag,初始化为FALSE,在SetCursorState中修改其值。另外响应WM_SETCURSOR消息,这样处理:
BOOL CGuardDataBackDlg::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
{
if (m_Flag)
{
SetCursor(LoadCursor(NULL, IDC_WAIT));
return TRUE;
}

return CDialog::OnSetCursor(pWnd, nHitTest, message);
}
闪破风浪 2009-01-06
  • 打赏
  • 举报
回复
那是Widows消息堆栈的问题吧?

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧