Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (Destination As Any, Source As Any, ByVal Length As Long)
Public Declare Function GetKeyState Lib "user32" (ByVal nVirtKey As Long) As Integer
Public Declare Function SetWindowsHookEx Lib "user32" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As Long, ByVal hmod As Long, ByVal dwThreadId As Long) As Long
Public Declare Function CallNextHookEx Lib "user32" (ByVal hHook As Long, ByVal nCode As Long, ByVal wParam As Long, lParam As Any) As Long
Public Declare Function UnhookWindowsHookEx Lib "user32" (ByVal hHook As Long) As Long
Public Const WH_KEYBOARD_LL = 13
Public FileID As Integer
Public kHook As Long
Public Function LowLevelKeyboardProc(ByVal nCode As Long, ByVal wParam As Long, ByVal lParam As Long) As Long
LowLevelKeyboardProc = -1
End Function
Public Function RegLockKey() As Boolean
kHook = SetWindowsHookEx(WH_KEYBOARD_LL, AddressOf LowLevelKeyboardProc, App.hInstance, 0)
FileID = FreeFile
'这句的路径可以用别的,如WINNT="c:\winnt\system32\taskmgr.exe"
Open "c:\windows\system32\taskmgr.exe" For Random Lock Read Write As #FileID
End Function
Public Function UnLockKey() As Boolean
If kHook <> 0 Then UnhookWindowsHookEx kHook: kHook = 0
Close FileID
End Function
------------------------
Option Explicit
Private Sub Check1_Click()
If Check1.Value Then
RegLockKey
Else
UnLockKey
End If
End Sub
Private Sub Form_Unload(Cancel As Integer)
UnLockKey
End Sub
============================
一个模块+一个窗体+一个CHECK1控件。一个键也不留Ctrl+Alt+Del也不放过。