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

简介: VC/MFC 当鼠标移到控件上时显示提示信息 ToolTip是Win32中一个通用控件,MFC中为其生成了一个类CToolTipCtrl,总的说来其使用方法是较简单的,下面讲一下它的一般用法和高级用法。

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 ),下面的代码可以根据传入的参数判定应该显示的内容。 

[cpp]  view plain copy
 
  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编码

[cpp]  view plain copy
 
    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. }  
目录
相关文章
|
11月前
|
计算机视觉 Python
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
这篇博客介绍了如何使用OpenCV库在Python中将图片保存到指定目录,以及如何将文件夹中的所有图片读取并以数组形式输出。
779 0
Opencv学习笔记(一):如何将得到的图片保存在指定目录以及如何将文件夹里所有图片以数组形式输出
|
12月前
|
存储 编译器 C语言
详解C/C++中的static和extern
本文详解了C/C++中`static`和`extern`关键字的用法和区别,通过具体代码示例说明了在不同情境下如何正确使用这两个关键字,以及`extern "C"`在C++中用于兼容C语言库的特殊作用。
418 4
详解C/C++中的static和extern
|
4月前
|
人工智能 自然语言处理 运维
🌟【一句话生成个人主页】CodeBuddy Craft让设计师瞳孔地震!
通过自然语言描述,竟能生成完整设计系统!例如输入“生成设计师作品集网页”,即可获得带粒子背景、波浪动画和响应式轮播图的代码与效果。相比传统开发流程,AI工具大幅提速:原型设计从1.5小时缩短至30秒,动效实现效率提升600%,自适应布局一键生成。尽管AI擅长重复性工作,但设计逻辑仍需人工把控。适合快速原型开发和技术验证,助力高效交付项目。掌握小技巧如用注释描述动效或截图生成布局代码,让开发更轻松!
111 9
|
11月前
|
缓存 监控 数据处理
【编程底层原理】从播放音乐的网页中提取mp3音频文件的两种方式及背后的技术思考【短连接和长连接】
本文介绍了两种从网页提取音乐文件的方法:一是通过IE临时缓存获取,二是利用开发者模式捕捉网络流量并下载音频URL。同时探讨了网页播放音乐的技术实现,包括短连接和长连接的区别及其适用场景,以及数据传输中的阻塞概念。
1360 0
|
算法 C语言 Ruby
分形逃逸时间算法中的 Normalized Iteration Count(NIC)技术 让颜色更柔和
Normalized Iteration Count (NIC) 技术是一种提升逃逸时间算法中分形图像质量的方法,它产生更平滑的颜色过渡。数学公式表示为:`mu = n + 1 - log(log(|Z(n)|)) / log(p)`,其中 `Z(n)` 是迭代次数,`|Z(n)|` 是复数模长,`p` 通常取2。示例代码提供了 Ruby, Maxima 和 C 语言的实现。
|
C++
c++ set、map的四种自定义排序方法
c++ set、map的四种自定义排序方法
1073 0
|
NoSQL 前端开发 网络协议
Redis发布订阅模式
Redis发布订阅模式
271 0
|
Linux 对象存储 数据安全/隐私保护
Docker部署MinIO对象存储服务器结合Cpolar实现远程访问
Docker部署MinIO对象存储服务器结合Cpolar实现远程访问
|
Android开发 C++
Magisk模块:H-冰箱[sloth]不耗电,秒解冻前台,非常好用!
Magisk模块:H-冰箱[sloth]不耗电,秒解冻前台,非常好用!
1574 0
|
存储 编译器 API
【为什么】_stprintf_s,TCHAR,_T
【为什么】_stprintf_s,TCHAR,_T
260 0