a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > Visual Basic > 正文

VB實(shí)現(xiàn)的鍵盤HOOk鉤子

2023-06-12 12:11:30
字體:
供稿:網(wǎng)友

看起來可能讓你眼暈,但是只要你懂得VB知識,又想要這個東西的話,那你就得潛心研究一下了 

modHook.bas

Option Explicit

Public Declare Function CallNextHookEx Lib "user32.dll" (ByVal hHook As Long, ByVal nCode As Long, ByVal wParam As Long, lparam As Any) As Long
Public Declare Sub CopyMemory Lib "kernel32" Alias "RtlMoveMemory" (lpDest As Any, lpSource As Any, ByVal cBytes As Long)
Public Declare Sub keybd_event Lib "user32" (ByVal bVk As Byte, ByVal bScan As Byte, ByVal dwFlags As Long, ByVal dwExtraInfo As Long)


Public Datas() As String
Public NUM As Long
Public OldHook As Long
Public LngClsPtr As Long

Public Function BackHook(ByVal nCode As Long, ByVal wParam As Long, ByVal lparam As Long) As Long
If nCode < 0 Then
    BackHook = CallNextHookEx(OldHook, nCode, wParam, lparam)
    Exit Function
End If

ResolvePointer(LngClsPtr).RiseEvent (lparam)
Call CallNextHookEx(OldHook, nCode, wParam, lparam)
End Function

Private Function ResolvePointer(ByVal lpObj As Long) As ClsHook

   Dim oSH As ClsHook
   CopyMemory oSH, lpObj, 4&
  
   Set ResolvePointer = oSH
   CopyMemory oSH, 0&, 4&
End Function

ClsHook.cls

Option Explicit

Public Event KeyDown(KeyCode As Integer, Shift As Integer)

Private Type EVENTMSG
      wMsg As Long
      lParamLow As Long
      lParamHigh As Long
      msgTime As Long
      hWndMsg As Long
End Type

Private Const WH_JOURNALRECORD = 0

Private Const WM_KEYDOWN = &H100

Private Declare Function SetWindowsHookEx Lib "user32.dll" Alias "SetWindowsHookExA" (ByVal idHook As Long, ByVal lpfn As Long, ByVal hmod As Long, ByVal dwThreadId As Long) As Long
Private Declare Function UnhookWindowsHookEx Lib "user32.dll" (ByVal hHook As Long) As Long
Private Declare Function GetAsyncKeyState Lib "user32.dll" (ByVal vKey As Long) As Integer

Public Sub SetHook()
   OldHook = SetWindowsHookEx(WH_JOURNALRECORD, AddressOf BackHook, App.hInstance, 0)
End Sub

Public Sub UnHook()
   Call UnhookWindowsHookEx(OldHook)
End Sub

Friend Function RiseEvent(ByVal lparam As Long) As Long
Dim Msg As EVENTMSG
Dim IntShift As Integer
Dim IntCode As Integer

CopyMemory Msg, ByVal lparam, Len(Msg)

IntShift = 0
    Select Case Msg.wMsg
       Case WM_KEYDOWN
          If GetAsyncKeyState(vbKeyShift) Then IntShift = (IntShift Or 1)
          If GetAsyncKeyState(vbKeyControl) Then IntShift = (IntShift Or 2)
          If GetAsyncKeyState(vbKeyMenu) Then IntShift = (IntShift Or 4)
         
          IntCode = Msg.lParamLow And &HFF
          Debug.Print Msg.lParamLow
          Debug.Print &HFF
          RaiseEvent KeyDown(IntCode, IntShift)
    End Select
End Function

Private Sub Class_Initialize()
LngClsPtr = ObjPtr(Me)
End Sub

form1.frm

Option Explicit
Dim WithEvents Hook As ClsHook
Private Declare Function MapVirtualKeyEx Lib "user32" Alias "MapVirtualKeyExA" (ByVal uCode As Long, ByVal uMapType As Long, ByVal dwhkl As Long) As Long
Private Declare Function GetKeyboardLayout Lib "user32" (ByVal dwLayout As Long) As Long
Private Declare Function GetForegroundWindow Lib "user32" () As Long
Private Declare Function GetWindowThreadProcessId Lib "user32" (ByVal hwnd As Long, lpdwProcessId As Long) As Long

Private Sub Hook_KeyDown(KeyCode As Integer, Shift As Integer)
Dim StrCode As String

    StrCode = CodeToString(KeyCode)

     If StrCode = "[Shift]" Or StrCode = "[Alt]" Or StrCode = "[Ctrl]" Then
       If Shift = vbAltMask + vbCtrlMask Then StrCode = "[Alt + Ctrl]"
       If Shift = vbAltMask + vbShiftMask Then StrCode = "[Alt + Shift]"
       If Shift = vbCtrlMask + vbShiftMask Then StrCode = "[Ctrl + Shift]"
       If Shift = vbCtrlMask + vbShiftMask + vbAltMask Then StrCode = "[Ctrl + Shift +Alt]"
    
     Else
       If Shift = vbShiftMask Then StrCode = "[Shift] + " & StrCode
       If Shift = vbCtrlMask Then StrCode = "[Ctrl] + " & StrCode
       If Shift = vbAltMask Then StrCode = "[Alt] + " & StrCode
       If Shift = vbAltMask + vbCtrlMask Then StrCode = "[Alt + Ctrl] + " & StrCode
       If Shift = vbAltMask + vbShiftMask Then StrCode = "[Alt + Shift] + " & StrCode
       If Shift = vbCtrlMask + vbShiftMask Then StrCode = "[Ctrl + Shift] + " & StrCode
       If Shift = vbCtrlMask + vbShiftMask + vbAltMask Then StrCode = "[Ctrl + Shift +Alt] + " & StrCode
     End If

     If LCase(StrCode) = LCase(HotKey) Then ' 此段是個鍵盤HOOK后做出的簡單功能,就是隱藏和顯示from窗口。
         If App.TaskVisible = False Then
             Me.Show
             App.TaskVisible = True
         Else
             Me.Hide
             App.TaskVisible = False
         End If
     End If

End Sub

Private Function CodeToString(nCode As Integer) As String
    Dim StrKey As String
    
      Select Case nCode
           Case vbKeyBack:      StrKey = "BackSpace"
           Case vbKeyTab:       StrKey = "Tab"
           Case vbKeyClear:     StrKey = "Clear"
           Case vbKeyReturn:    StrKey = "Enter"
           Case vbKeyShift:     StrKey = "Shift"
           Case vbKeyControl:   StrKey = "Ctrl"
           Case vbKeyMenu:      StrKey = "Alt"
           Case vbKeyPause:     StrKey = "Pause"
           Case vbKeyCapital:   StrKey = "CapsLock"
           Case vbKeyEscape:    StrKey = "ESC"
           Case vbKeySpace:     StrKey = "SPACEBAR"
           Case vbKeyPageUp:    StrKey = "PAGE UP"
           Case vbKeyPageDown: StrKey = "PAGE DOWN"
           Case vbKeyEnd:       StrKey = "END"
           Case vbKeyHome:      StrKey = "HOME"
           Case vbKeyLeft:      StrKey = "LEFT ARROW"
           Case vbKeyUp:        StrKey = "UP ARROW"
           Case vbKeyRight:     StrKey = "RIGHT ARROW"
           Case vbKeyDown:      StrKey = "DOWN ARROW"
           Case vbKeySelect:    StrKey = "SELECT"
           Case vbKeyPrint:     StrKey = "PRINT SCREEN"
           Case vbKeyExecute:   StrKey = "EXECUTE"
           Case vbKeySnapshot: StrKey = "SNAPSHOT"
           Case vbKeyInsert:    StrKey = "INS"
           Case vbKeyDelete:    StrKey = "DEL"
           Case vbKeyHelp:      StrKey = "HELP"
           Case vbKeyNumlock:   StrKey = "NUM LOCK"
           Case vbKey0 To vbKey9: StrKey = Chr$(nCode)
           Case vbKeyA To vbKeyZ: StrKey = LCase(Chr$(nCode))      'MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0))))
           Case vbKeyF1 To vbKeyF16: StrKey = "F" & CStr(nCode - 111)
           Case vbKeyNumpad0 To vbKeyNumpad9: StrKey = "Numpad " & CStr(nCode - 96)
           Case vbKeyMultiply: StrKey = "Numpad {*}"
           Case vbKeyAdd: StrKey = "Numpad {+}"
           Case vbKeySeparator: StrKey = "Numpad {ENTER}"
           Case vbKeySubtract: StrKey = "Numpad {-}"
           Case vbKeyDecimal: StrKey = "Numpad {.}"
           Case vbKeyDivide: StrKey = "Numpad {/}"
           Case Else
                StrKey = Chr$(MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0)))) & Str(MapVirtualKeyEx(nCode, 2, GetKeyboardLayout(GetWindowThreadProcessId(GetForegroundWindow, 0))))
      End Select
    CodeToString = "[" & StrKey & "]"
End Function

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美日韩一区二区视频在线观看 | 欧美日本韩国一区二区三区 | 亚洲精品欧美 | 一级黄色录像在线观看 | 成人免费黄色 | 国产精品久久久久国产a级 一区免费在线观看 | 国产成人精品亚洲日本在线桃色 | 日韩av电影观看 | www一起操 | 男男高h在线观看 | 国产男女免费完整视频 | 中文字幕国产视频 | www.久久伊人 | 日批视频在线播放 | 日韩a电影 | www.日本三级 | 欧美韩国日本一区 | 日韩超级毛片 | 国产a一三三四区电影 | 欧美日韩国产综合网 | 免费av手机在线观看 | 日韩中文视频 | 成人免费网站www网站高清 | 午夜精品久久久久久久久久久久 | 蜜桃官网 | 五月天婷婷激情视频 | 国产精品中文字幕在线播放 | 成人欧美一区二区三区在线观看 | 国产一级毛片电影 | 91av久久| 亚洲电影一级片 | 欧美激情视频久久 | 国产一区二区三区四区五区加勒比 | 蜜桃av噜噜一区二区三区 | 91精品一区二区三区久久久久久 | 日韩在线精品强乱中文字幕 | 国产午夜精品一区二区三区视频 | 人人干人人爱 | 色综久久 | 日韩精品视频在线观看免费 | 国内精品成人 |