USUÁRIO:      SENHA:        SALVAR LOGIN ?    Adicione o VBWEB na sua lista de favoritos   Fale conosco 

 

  Fórum

  Visual Basic
Voltar
Autor Assunto:  Travar tecla Windows
IceEyes
BRASIL
MS - BRASIL
Postada em 30/01/2008 15:51 hs            
Tem como travar a teclad Windows e CTRL+ESC? pelo vb6???
     
ghost_jlp
Pontos: 2843 Pontos: 2843 Pontos: 2843 Pontos: 2843
SÃO PAULO
SP - BRASIL
Postada em 30/01/2008 21:10 hs            
Opa, tem sim amigo vamos lá que o negócio só parece complicado... hehehe
 
1) Crie um módulo e cole isso nele:
 
'-------------------------------------------------------------------------------
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_STARTKEY = &H5B

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
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_ESCAPE) And ((GetKeyState(VK_CONTROL) And &H8000) <> 0)) Or _
            p.vkCode = VK_STARTKEY
           
        End If
    End If
   
    If fEatKeystroke Then
        LowLevelKeyboardProc = -1
    Else
        LowLevelKeyboardProc = CallNextHookEx(0, nCode, wParam, ByVal lParam)
    End If
End Function
 
'-------------------------------------------------------------------------------
 
2) No form coloque assim:
 
'-------------------------------------------------------------------------------
 
Dim hhkLowLevelKybd as Long
 
Private Sub Form_Load()
hhkLowLevelKybd = SetWindowsHookEx(WH_KEYBOARD_LL, AddressOf LowLevelKeyboardProc, App.hInstance, 0)
End Sub
 
Private Sub Form_Unload(Cancel As Integer)
UnhookWindowsHookEx hhkLowLevelKybd
hhkLowLevelKybd = 0
End Sub
 
 
 
 
ao carregar o form ele trava o CTRL+ESC, ao fechar ele habilita de novo
 
Espero que ajude
 
at+
 
obs.: Qualquer problema postae
     
IceEyes
BRASIL
MS - BRASIL
ENUNCIADA !
Postada em 31/01/2008 10:49 hs            
Valeus aew ghost_jlp bombou fera o codigo aki mas e o botão do Windows??? pq eu aperto ele e funciona.. essa tecla não tem como travar?
   
ghost_jlp
Pontos: 2843 Pontos: 2843 Pontos: 2843 Pontos: 2843
SÃO PAULO
SP - BRASIL
Postada em 01/02/2008 18:37 hs            
Mano... comigo travou... o meu SO é WinXP...
     
emanum
VIAMAO
RS - BRASIL
ENUNCIADA !
Postada em 01/02/2008 22:02 hs            
Amigos dependem se vcs querem travar uma tecla especifica ou todo o teclado? Fiz um sistema para uma lan onde travava todo o teclado e e bem simples
   
Página(s): 1/1    


Seu Nome:

Seu eMail:

ALTERAR PARA MODO HTML
Mensagem:

[:)] = 
[:P] = 
[:(] = 
[;)] = 

HTML DESLIGADO

     
 VOLTAR

  



CyberWEB Network Ltda.    © Copyright 2000-2024   -   Todos os direitos reservados.
Powered by HostingZone - A melhor hospedagem para seu site
Topo da página