//以下代码在Delphi7 + XP SP3下测试通过 //button1为注册钩子屏蔽,button2为卸载钩子取消屏蔽F1 unit Unit1; interface uses Windo

来源:互联网 发布:斯巴达英雄java游戏 编辑:程序博客网 时间:2024/06/05 15:34
//以下代码在Delphi7 + XP SP3下测试通过
//button1为注册钩子屏蔽,button2为卸载钩子取消屏蔽F1

unit Unit1;

interface

uses
Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, StdCtrls;

type
TForm1 = class(TForm)
Button1: TButton;
Button2: TButton;
procedure Button1Click(Sender: TObject);
procedure Button2Click(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
end;

var
Form1: TForm1;
WM_Sock :Integer;
hHandle :HWND;
Hook :HHook;
implementation

{$R *.dfm}
function LowLevelKeyboardProc(vNode:Integer;wParam:WPARAM;lParam:LPARAM):LRESULT;stdcall;
type
KbDllHookStruct = record
vkCode:DWord;
ScanCode:DWord;
Flags:DWord;
Time:DWord;
dwExtraInfo:DWord;
end;
var
P:^KbDllHookStruct;
begin
Result := 0;
P := Pointer(LPARAM);
if vNode = HC_ACTION then
begin
case wParam of
WM_KEYDOWN,WM_SYSKEYDOWN,WM_KEYUP,WM_SYSKEYUP:
if p.vkCode = VK_F1 then //判断按下的是不是F1
begin
Result := 1;
end;
end;
if vNode <> 0 then
Result := CallNextHookEx(0,vNode,wParam,lParam);
end;
end;

//注册钩子
procedure TForm1.Button1Click(Sender: TObject);
const
WH_KEYBOARD_LL = 13;
begin
WM_SOCK := 0;
WM_SOCK := RegisterWindowMessage('WM_SOCK');
hHandle := Handle;
Hook := SetWindowsHookEx(WH_KEYBOARD_LL,LowLevelKeyboardProc,hInstance,0);
end;

//卸载钩子
procedure TForm1.Button2Click(Sender: TObject);
begin
UnHookWindowsHookEx(Hook);
end;

end.
原创粉丝点击