keys as the one of Windows or the whole keyboard.

  • Thread starter Thread starter Frank Dulk
  • Start date Start date
F

Frank Dulk

Hello

I am developing a software for administration of LAN HOUSE (LAN GAMES) and
it would like to join keys as the one of Windows or the whole keyboard.

Does anybody have some API?

I found this code that works perfectly in Visual Basic.

However in the access it happens mistake with App.hInstance

To Block

hhkLowLevelKybd = SetWindowsHookEx(WH_KEYBOARD_LL, AddressOf
LowLevelKeyboardProc, App.hInstance, 0)


To Unblock

UnhookWindowsHookEx hhkLowLevelKybd
hhkLowLevelKybd = 0


Declarations

Option Explicit

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 HC_ACTION = 0
Public Const WM_KEYDOWN = &H100
Public Const WM_KEYUP = &H101
Public Const WM_SYSKEYDOWN = &H104
Public Const WM_SYSKEYUP = &H105
Public Const VK_TAB = &H9
Public Const VK_CONTROL = &H11
Public Const VK_ESCAPE = &H1B
Public Const VK_LEFTWINKEY = &H5B
Public Const VK_RIGHTWINKEY = &H5C

Public Const WH_KEYBOARD_LL = 13
Public Const LLKHF_ALTDOWN = &H20

Public Type KBDLLHOOKSTRUCT
vkCode As Long
scanCode As Long
flags As Long
time As Long
dwExtraInfo As Long
End Type

Dim p As KBDLLHOOKSTRUCT

Public Function LowLevelKeyboardProc(ByVal nCode As Long, ByVal wParam As
Long, ByVal lParam As Long) As Long
Dim fEatKeystroke As Boolean

If (nCode = HC_ACTION) Then
If wParam = WM_KEYDOWN Or wParam = WM_SYSKEYDOWN Or wParam = WM_KEYUP
Or wParam = WM_SYSKEYUP Then
CopyMemory p, ByVal lParam, Len(p)
fEatKeystroke = _
(p.vkCode = VK_LEFTWINKEY) Or _
(p.vkCode = VK_RIGHTWINKEY) 'Or _
'((p.vkCode = VK_TAB) And ((p.flags And LLKHF_ALTDOWN) <> 0)) Or
_
'((p.vkCode = VK_TAB) And ((p.flags And LLKHF_ALTDOWN) <> 0)) Or
_
'((p.vkCode = VK_ESCAPE) And ((p.flags And LLKHF_ALTDOWN) <> 0))
Or _
'((p.vkCode = VK_ESCAPE) And ((GetKeyState(VK_CONTROL) And
&H8000) <> 0))
End If
End If

If fEatKeystroke Then
LowLevelKeyboardProc = -1
Else
LowLevelKeyboardProc = CallNextHookEx(0, nCode, wParam, ByVal
lParam)
End If
End Function



Some clue to work in Access?
 
You might want to expand on exactly what you are trying to do with the key
press.

All forms in ms-access have a keydown event, and thus you don't need a api
to trap the key stroke.

You probably can get the api code to work, but I not willing to waste my
time looking through that big ugly mess you posted until I know it is worth
the time to do so...
 
Amigo,

Neguem comprendo o que voce escrever. Sua ingles esta horrivel. Procura um
melhor traducor!
 
Ok, I give up!

It's not Spanish.

It's not Portugese.

What is it?

TC


Paul Overway said:
Amigo,

Neguem comprendo o que voce escrever. Sua ingles esta horrivel. Procura um
melhor traducor!

(snip)
 
Back
Top