VC++利用钩子实现菜单阴影效果.docVIP

VC++利用钩子实现菜单阴影效果.doc

此“医疗卫生”领域文档为创作者个人分享资料,不作为权威性指导和指引,仅供参考
  1. 1、本文档共13页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
利用钩子实现菜单阴影效果程序运行效果截图:   也许有很多人曾和我一样, 对Office XP里面的菜单的阴影效果羡慕不已,它不需要在Windows XP 中就可以在菜单后面显示阴影, 当然在Windows XP中, 已经完全支持菜单阴影了。虽然我们不一定很有必要自己来实现这个较难实现的效果。但是正如有很多人想实现那种IE风格的菜单栏一样,尽管它 们并不能为我们带来更多实用的功能, 却可以使我们的程序看起来与众不同。:) ??菜单也是一个窗口, 假如我们能得到它的窗口的句柄, 要实现像添加阴影这样的效果, 就不会很难了。可惜我们根本找不到这个窗口是在哪里被创建的,也没办法很容易地取得它的窗口句柄,甚至几乎难以相信它是一个窗口,因为我实在找不到它的窗口句柄啊。经过对许多别人已经做好的类的源代码的研究, 我终于找到了一个方法。那就是万能的钩子,如果说在Windows里面抓人,连钩子也办不到的话,那我就不知道该用什么方法实现了,呵呵。 ??下面我就一起来看看如何抓到这些可恶的家伙吧。为了便于移植,我们就写一个专用的类吧,就取名为CMenuWndHook。添加两个静态成员先: static CMap m_WndMenuMap; static HHOOK m_hMenuHook; ? 被我们抓到的这些家伙肯定不止一个,我们需要一个映射模板类来保存它们的句柄和对应的CMenuWndHook 类对象的指针。m_hMenuHook则为我们将要创建的钩子的钩子句柄。再在CPP文件中初始化它们: CMap CMenuWndHook::m_WndMenuMap; HHOOK CMenuWndHook::m_hMenuHook = NULL; 下面再添加两个函数来做安装与卸载hook之用, 它们都是静态函数: void CMenuWndHook::InstallHook() { ??if (m_hMenuHook == NULL) ??{ ?? m_hMenuHook = ::SetWindowsHookEx(WH_CALLWNDPROC, ???????????????????WindowHook, ?? AfxGetApp()-m_hInstance, ?????????????????? ::GetCurrentThreadId()); ??} } Windows之下一般用上面的SetWindowsHookEx API函数来安装HOOK,它的函数原型如下: HHOOK SetWindowsHookEx(int idHook, //钩子的类型,即它处理的消息类型       HOOKPROC lpfn, ?//子函数的入口地址,当钩子钩到任何消息后先调用这个函数。? ?// (如果dwThreadId参数为0,或是一个由别的进程创建的线程的标识, ?//lpfn必须指向DLL中的钩子子程。除此以外,lpfn可以指向当前进 ?//程的一段钩子子程代码)       HINSTANCE hMod, //应用程序实例的句柄。标识包含lpfn所指的子程的DLL。? ?// 如果dwThreadId标识当前进程创建的一个线程, ?//而且子程代码位于当前进程,hMod必须为NULL。 ?//可以很简单的设定其为本应用程序的实例句柄。       DWORD dwThreadId //与安装的钩子子程相关联的线程的标识符。 ?//如果为0,钩子子程与所有的线程关联,即为全局钩子。 ?//但这时,你钩子只能是放在DLL中。??????      ); ??函数成功则返回钩子子程的句柄,失败返回NULL。 我们用到的是WH_CALLWNDPROC类型的钩子,它使你可以监视发送到窗口过程的消息, 系统在消息发送到 接收窗口过程之前会调用你指定的WH_CALLWNDPROC Hook 子程,这样你就可以等它们自投罗网,然后就可以 对它们为所欲为了。 卸载钩子就简单多了,只需要调用UnhookWindowsHookEx即可,当然,我们还需要额外做一点清理工作: void CMenuWndHook::UnInstallHook() { ??POSITION pos = m_WndMenuMap.GetStartPosition(); while (pos != NULL) ??{ ????HWND hwnd; ????CMenuWndHook *pMenuWndHook; ?m_WndMenuMap.GetNextAssoc(pos, hwnd,?pMenuWndHook); ?delete pMenuWndHook; ?pMenuWndHook= NULL; } m

文档评论(0)

phl805 + 关注
实名认证
文档贡献者

建筑从业资格证持证人

该用户很懒,什么也没介绍

领域认证该用户于2023年05月12日上传了建筑从业资格证

1亿VIP精品文档

相关文档