当前位置:首页>网络学院>程序开发>c#教程>文章内容

在C#中使用钩子实现Alt+F4健窗口最小化功能

[ 来源:http://www.it55.com | 作者: | 时间:2008-01-11 | 收藏 | 推荐 ] 【

     
  相信以前用过VB、Delphi,特别是VC的程序员应该对钩子程序都不陌生。在C#中我们同样可以使用钩子程序来实现特殊效果,比如当用户按下某个特殊键时提示,比如关闭应用程序前提示等。
  当然使用方法相对VC来说要稍微复杂一点,有的地方还不太方便,下面的例子中实现两个基本功能:
  1、按下Alt+F4时使窗口最小化
  2、关闭应用程序前提示
  
  一、加入winuser.h中的定义
  因为钩子程序一般情况下都是在vc下使用的,在c#里面并没有对应的方法、结构等的定义,我们首先需要把winuser.h中的相关定义加入自己的类
  
  
  钩子类型的枚举
   public enum HookType : int
   {
   WH_JOURNALRECORD = 0,
   WH_JOURNALPLAYBACK = 1,
   WH_KEYBOARD = 2,
   WH_GETMESSAGE = 3,
   WH_CALLWNDPROC = 4,
   WH_CBT = 5,
   WH_SYSMSGFILTER = 6,
   WH_MOUSE = 7,
   WH_HARDWARE = 8,
   WH_DEBUG = 9,
   WH_SHELL = 10,
   WH_FOREGROUNDIDLE = 11,
   WH_CALLWNDPROCRET = 12,
   WH_KEYBOARD_LL = 13,
   WH_MOUSE_LL = 14
   }具体的说明在msdn中都可以查到,主要的比如WH_KEYBOARD是监控按键事件,WH_CALLWNDPROC是在消息触发时执行
  
  虚键值的定义
   public enum VirtualKeys
   {
   VK_SHIFT = 0x10,
   VK_CONTROL = 0x11,
   VK_MENU = 0x12, //ALT
   VK_PAUSE = 0x13,
   VK_CAPITAL = 0x14
   }这个不用说明了,对应ALT、CTRL等键
  
  消息结构体
   public struct CWPSTRUCT
   {
   public IntPtr lparam;
   public IntPtr wparam;
   public int message;
   public IntPtr hwnd;
   }这个是windows内部传递过来的消息的结构
  
  二、加入自己定义的委托和事件参数
  钩子委托
   public delegate int HookProc(int code, IntPtr wParam, IntPtr lParam);
   public delegate void HookEventHandler(object sender, HookEventArgs e);
  HokkProc是SetWindowsHookEx调用时的委托事件,HookEventHandler是自己的委托事件
  钩子事件参数
   public class HookEventArgs : EventArgs
   {
   public int HookCode;
   public IntPtr wParam;
   public IntPtr lParam;
   public Keys key;
   public bool bAltKey;
   public bool bCtrlKey;
   }是自己的委托事件中接受的事件参数
  
  三、实现自己的钩子类
  这一步是最重要的,要使用钩子,我们需要引用user32.dll中的相应方法:
   [DllImport("user32.dll")]
   static extern IntPtr SetWindowsHookEx(HookType hook, HookProc callback, IntPtr hMod, uint dwThreadId);
  
   [DllImport("user32.dll")]
   static extern bool UnhookWindowsHookEx(IntPtr hhk);
  
   [DllImport("user32.dll")]
   static extern int CallNextHookEx(IntPtr hhk, int nCode, IntPtr wParam, IntPtr lParam);
  
   [DllImport("user32.dll")]
   static extern short GetKeyState(VirtualKeys nVirtKey);
  SetWindowsHookEx是注册一个钩子程序,UnhookWindowsHookEx是释放钩子程序,CallNextHookEx调用钩子的后续事件处理,GetKeyState得到所按的虚键
  
  然后就可以调用这些方法来实现钩子程序,比如注册一个钩子可以调用:
   m_hook = SetWindowsHookEx(m_hooktype, m_hookproc, IntPtr.Zero, (uint)AppDomain.GetCurrentThreadId());
  其中m_hooktype就是HookType中定义的类型,m_hookproc就是实际的钩子处理程序:
  m_hookproc = new HookProc(KeyHookProcedure);
  最关键的就是KeyHookProcedure等钩子处理程序:
   protected int KeyHookProcedure(int code, IntPtr wParam, IntPtr lParam)
   {
   if (code != 0)
   {
   return CallNextHookEx(m_hook, code, wParam, lParam);
   }
  
   if (HookInvoked != null)
   {
   Keys key = (Keys)wParam.ToInt32();
   HookEventArgs eventArgs = new HookEventArgs();
   eventArgs.key = key;
   eventArgs.lParam = lParam;
   eventArgs.wParam = wParam;
   eventArgs.HookCode = code;
   eventArgs.bAltKey = GetKeyState(VirtualKeys.VK_MENU) <= -127;
   eventArgs.bCtrlKey = GetKeyState(VirtualKeys.VK_CONTROL) <= -127;
   HookInvoked(this, eventArgs);

(编辑:IT资讯之家 www.it55.com

返回顶部
共4页: 上一页 1 [2] [3] [4] 下一页  

网友评论

[以下评论为网友观点,不代表本站。请自觉遵守互联网相关政策法规,所有连带责任均有评论者自负。]
[不超过250字]