VC/MFC 当鼠标移到控件上时显示提示信息

ToolTip是Win32中一个通用控件,MFC中为其生成了一个类CToolTipCtrl,总的说来其使用方法是较简单的,下面讲一下它的一般用法和高级用法。 


一般用法步骤:  


添加CToolTipCtrl成员变量 m_tt。  


在父窗口中调用EnableToolTips(TRUE);  


在窗口的OnCreate(或者其他适当的位置)中向ToolTip中添加需要显示Tip的子窗口,并同时指定相应的显示字串CToolTipCtrl::AddTool(pWnd, "string to display ")。 


重载父窗口的 BOOL PreTranslateMessage(MSG* pMsg) ,在函数中调用 m_tt.RelayEvent(pMsg)。  


下面假设在窗口CWndYour中使用CToolTipCtrl  


在类定义中添加变量说明:  

class CWndYour:xxx  

{  

CToolTipCtrl m_tt;  

}  

在OnCreate中添加需要显示Tip的子窗口  

CWndYour::OnCreate(....)  

{  

EnableToolTips(TRUE);  

m_tt.Create(this);  

m_tt.Activate(TRUE);  


CWnd* pW=GetDlgItem(IDC_CHECK1);//得到窗口指针  

m_tooltip.AddTool(pW, "Check1 ");//添加  

........  

}  

在BOOL PreTranslateMessage(MSG* pMsg)中添加代码  

BOOL CWndYour::PreTranslateMessage(MSG* pMsg)  

{  

{  

m_tt.RelayEvent(pMsg);  

}  

return CParentClass::PreTranslateMessage(pMsg);  

}  


这样当鼠标移动到相应的子窗口上时会显示出相应的ToolTip。  


动态改变ToolTip的显示内容的方法及步骤:  


上面所讲的1、2、4步骤。  


在增加ToolTip时不指定显示的字串,而是使用LPSTR_TEXTCALLBACK。  


在窗口中增加消息映射 ON_NOTIFY_EX( TTN_NEEDTEXT, 0, SetTipText )。  


在窗口中增加一个函数用于动态提供显示内容,其原型为 BOOL SetTipText( UINT id, NMHDR * pTTTStruct, LRESULT * pResult ),下面的代码可以根据传入的参数判定应该显示的内容。 




 

 


  1. BOOL CWndYour::SetTipText( UINT id, NMHDR * pTTTStruct, LRESULT * pResult )    
  2. {    
  3. TOOLTIPTEXT *pTTT = (TOOLTIPTEXT *)pTTTStruct;     
  4. UINT nID =pTTTStruct-> idFrom; //得到相应窗口ID,有可能是HWND    
  5. if (pTTT-> uFlags & TTF_IDISHWND) //表明nID是否为HWND    
  6. {    
  7.   nID = ::GetDlgCtrlID((HWND)nID);//从HWND得到ID值,当然你也可以通过HWND值来判断    
  8. switch(nID)    
  9. case(IDC_YOUR_CONTROL1)     
  10. strcpy(pTTT-> lpszText,your_string1);//设置    
  11. return TRUE;    
  12. break;    
  13. case(IDC_YOUR_CONTROL2)    
  14. //设置相应的显示字串    
  15. return TRUE;    
  16. break;    
  17. }    
  18. return(FALSE);    
  19. }   


另外的就是在相应函数中区分UNICODE编码




 

 


  1. BOOL CPreParent::OnToolTipText(UINT, NMHDR* pNMHDR, LRESULT* pResult)  
  2. {  
  3.     ASSERT(pNMHDR->code == TTN_NEEDTEXTA || pNMHDR->code == TTN_NEEDTEXTW);  
  4.       
  5.     // UNICODE消息  
  6.     TOOLTIPTEXTA* pTTTA = (TOOLTIPTEXTA*)pNMHDR;  
  7.     TOOLTIPTEXTW* pTTTW = (TOOLTIPTEXTW*)pNMHDR;  
  8.     //TCHAR szFullText[512];  
  9.     CString strTipText;  
  10.     UINT nID = pNMHDR->idFrom;  
  11.       
  12.     if (pNMHDR->code == TTN_NEEDTEXTA && (pTTTA->uFlags & TTF_IDISHWND) ||  
  13.         pNMHDR->code == TTN_NEEDTEXTW && (pTTTW->uFlags & TTF_IDISHWND))  
  14.     {  
  15.         // idFrom为工具条的HWND   
  16.         nID = ::GetDlgCtrlID((HWND)nID);  
  17.     }  
  18.       
  19.     if (nID != 0) //不为分隔符  
  20.     {  
  21.         strTipText.LoadString(nID);  
  22.         strTipText = strTipText.Mid(strTipText.Find('\n',0)+1);  
  23.         //strTipText = _T("notify string");  
  24.           
  25. #ifndef _UNICODE  
  26.         if (pNMHDR->code == TTN_NEEDTEXTA)  
  27.         {  
  28.             lstrcpyn(pTTTA->szText, strTipText, sizeof(pTTTA->szText));  
  29.         }  
  30.         else  
  31.         {  
  32.             _mbstowcsz(pTTTW->szText, strTipText, sizeof(pTTTW->szText));  
  33.         }  
  34. #else  
  35.         if (pNMHDR->code == TTN_NEEDTEXTA)  
  36.         {  
  37.             _wcstombsz(pTTTA->szText, strTipText,sizeof(pTTTA->szText));  
  38.         }  
  39.         else  
  40.         {  
  41.             lstrcpyn(pTTTW->szText, strTipText, sizeof(pTTTW->szText));  
  42.         }  
  43. #endif  
  44.           
  45.         *pResult = 0;  
  46.           
  47.         //使工具条提示窗口在最上面  
  48.         ::SetWindowPos(pNMHDR->hwndFrom, HWND_TOP, 0, 0, 0, 0,  
  49.             SWP_NOACTIVATE|SWP_NOSIZE|SWP_NOMOVE|SWP_NOOWNERZORDER);   
  50.         return TRUE;  
  51.     }  
  52.     return TRUE;  
  53. }