CTrackThread::PreTranslateMessage(MSG* pMsg)

MFC消息控制流最具特色的地方是CWnd类的虚拟函数PreTranslateMessage(),通过重载这个函数,我们可以改变MFC的消息控制流程,甚至可以作一个全新的控制流出来。只有穿过消息队列的消息才受PreTranslateMessage()影响,而采用SendMessage()或其他类似的方式向窗口直接发送的而不经过消息队列的消息根本不会理睬PreTranslateMessage()的存在。 

一、是否调用TranslateMessage()和DispatchMessage()是由一个名称为PreTranslateMessage()函数的返回值决定的,如果该函数返回TRUE,则不会把该消息分发给窗口函数处理。 

二、传给PreTranslateMessage()的消息是未经翻译过的消息,它没有经过TranslateMessage()处理。可以在该函数中使用(pMsg->wParam==VK_RETURN)来拦截回车键。 

三、在WindowProc里不能处理WM_Char消息。 

四、SetWindowText会发送WM_Char给窗口。 

五、PeekMessage和GetMessage的区别:
GetMessage在没有消息的时候等待消息,cpu当然低 
PeekMessage没有消息的时候立刻返回,所以cpu占用率高。 
因为游戏不能靠windows消息驱动,所以要用PeekMessage(); 
例子:
  1. BOOL CYourWnd::PreTranslateMessage(CMsg *pMsg) 
  2.     if(pMsg->message == WM_KEYDOWN) 
  3.     { 
  4.         if(pMsg->wParam == 'A'
  5.         { 
  6.             //...... 
  7.         } 
  8.         //...... 
  9.     } 
  10.     if(pMsg->message == WM_KEYUP) 
  11.     { 
  12.         int nVirtKey = (int) pMsg->wParam; // virtual-key code 
  13.         switch(nVirtKey) 
  14.         { 
  15.         case VK_UP: 
  16.             //... 
  17.             AfxMessageBox("Up"); 
  18.             break
  19.         case VK_DOWN: 
  20.             //... 
  21.             AfxMessageBox("Down"); 
  22.             break
  23.             
  24.         case VK_ESCAPE: 
  25.             AfxMessageBox("esc"); 
  26.             return TRUE; 
  27.             break
  28.         }
  29.     }
  30. }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值