Trucos Registrar Hot-Keys con nuestra aplicación

Extraído de la web del Guille (http://guille.costasol.net)

Con este ejemplo lo que se hará es asignar las teclas Ctrl+F para que al pulsa esa combinación de teclas, se active nuestra aplicación.
No he hecho pruebas con una aplicación real, pero todo será cuestión de hacerlo...

Para hacer la prueba, crea un nuevo proyecto y añade el siguiente código:
'------------------------------------------------------------------
'Prueba para registrar una combinación de teclas (06/Dic/98)
'y activar la aplicación al recibirlas...
'
'El código para esperar a que se reciban los mensajes, está
'inspirado en el código de Francisco Charte para usar Drag&Drop
'con el VB4
'
'©Guillermo 'guille' Som, 1998
'------------------------------------------------------------------
Option Explicit

Private Declare Function RegisterHotKey Lib "user32" _
        (ByVal hWnd As Long, ByVal id As Long, ByVal fsModifiers As Long, ByVal vk As long) As Long

Private Declare Function UnregisterHotKey Lib "user32" (ByVal hWnd As Long, ByVal id As Long) As Long

Private Const MOD_ALT = &H1
Private Const MOD_CONTROL = &H2
Private Const MOD_SHIFT = &H4

Private Const WM_HOTKEY = &H312

'Tipos de datos para las funciones del API
Private Type POINTAPI
    x As Long
    y As Long
End Type

Private Type Msg
    hWnd As Long
    message As Long
    wParam As Long
    lParam As Long
    time As Long
    pt As POINTAPI
End Type 'MSG

Private Const PM_REMOVE = &H1

'funciones para recibir los mensajes de windows
Private Declare Function PeekMessage Lib "user32" Alias "PeekMessageA" _
        (lpMsg As Msg, ByVal hWnd As Long, ByVal wMsgFilterMin As Long, _
         ByVal wMsgFilterMax As Long, ByVal wRemoveMsg As Long) As Long
Private Declare Function WaitMessage Lib "user32" () As Long

Private Termina As Boolean


Private Sub ProcesaMensajes()
    'Para leer mensajes de la cola
    Dim Mensaje As Msg

    'Mientras Termina no sea True
    Do While Not Termina
        'esperamos a que llegue un mensaje
        WaitMessage
        'Si ese mensaje es WM_HOTKEY
        If PeekMessage(Mensaje, Me.hWnd, WM_HOTKEY, WM_HOTKEY, PM_REMOVE) Then
            'Restauramos el formulario al estado normal
            'por si está minimizado
            WindowState = vbNormal
            'Mostramos el form
            Show
        End If
        'permitimos el trabajo de otros procesos
        DoEvents
    Loop
End Sub

Private Sub Form_Load()
    'registrar las teclas para activación de esta aplicación
    Dim ret As Long

    Termina = False

    'La tecla Crtl+F será la que activará este formulario
    ret = RegisterHotKey(Me.hWnd, &HBFFF&, MOD_CONTROL, vbKeyF)
    'If ret Then
    ' Label2 = "Se ha registrado de forma correcta el Hot-Key"
    'Else
    ' Label2 = "No se ha registrado el Hot-Key"
    'End If

    'Hay que mostrar el form
    'sino entrará en el bucle de espera de mensajes sin mostrarse
    Show
    ProcesaMensajes
End Sub

Private Sub Form_Unload(Cancel As Integer)
    Termina = True
    'Quitar la Hot-Key registrada
    Call UnregisterHotKey(Me.hWnd, &HBFFF&)
End Sub



Trucos Trucos

Visual Basic Página de Visual Basic

Página principal Página principal

www.jrubi.com