Developpez.com - C
X

Choisissez d'abord la catégorieensuite la rubrique :



API Windows en C

Les raccourcis clavier ou HotKey.

Par CGi

Le 15 juillet 2015




Introduction :

Les raccourcis clavier ou HotKey sont semblable aux accélérateurs clavier à la différence qu'il peuvent être modifier pendant l'éxécution du programme et qu'ils sont actif même si l'application n'a pas le focus clavier.


Création d'un raccourcis clavier :

Pour créer un racourcis clavier on utilise la fonction RegisterHotKey, dont voici un exemple d'utilisation :


    RegisterHotKey(hwnd, HK_CTRL_H, MOD_CONTROL, 'H');

Elle prend comme paramètres dans l'ordre suivant : le handle de la fenètre qui réceptionne le raccourcis clavier, puis une constante entiere qui sera l'identificateur du racourcis, puis un entier qui est la combinaison de constante qui indique si une touche étendu est enfoncée, puis le code (virtual key code) de la touche de raccourcis.
Les constantes de touches étendues sont : MOD_ALT pour la touche Alt, MOD_CONTROL pour la touche Ctrl, MOD_SHIFT pour la touche majuscule et MOD_WIN pour la touche Windows.


Réception du raccourcis clavier :

Quand une HotKey enregistrée est actionnée, Windows envoi un message WM_HOTKEY à la fenêtre, ce message contient dans son paramètre wParam l'identificateur de la HotKey.

        case WM_HOTKEY:
            if(wParam==HK_CTRL_H)
               MessageBox(hwnd, "Evenement Hot Key : Ctrl H ", "Titre", MB_OK );
            return 0;

Pour retirer une HotKey on appelle la fonction UnregisterHotKey avec comme paramètre le handle de fenêtre suivi de l'identificateur de la HotKey.

Code complet :

#include <windows.h>

#define IDM_QUIT 100
#define HK_CTRL_H 200

LRESULT CALLBACK MainWndProc(HWND, UINT, WPARAM, LPARAM);

int WINAPI WinMain(HINSTANCE hinstance, HINSTANCE hPrevInstance,
                                                  LPSTR lpCmdLine, int nCmdShow)
{
    HWND hwnd;
    MSG msg;
    WNDCLASS wc;
    HMENU hMenu, hSousMenu;

    wc.style = 0;
    wc.lpfnWndProc = MainWndProc;
    wc.cbClsExtra = 0;
    wc.cbWndExtra = 0;
    wc.hInstance = hinstance;
    wc.hIcon = NULL;
    wc.hCursor = LoadCursor(NULL, IDC_ARROW);
    wc.hbrBackground =  (HBRUSH)(COLOR_APPWORKSPACE+1);
    wc.lpszMenuName =  NULL;
    wc.lpszClassName = "mainWinClass";

    if(!RegisterClass(&wc)) return FALSE;

    hSousMenu = CreateMenu();
    AppendMenu(hSousMenu, MF_STRING, IDM_QUIT, "Quitter\tAtl-F4");
    hMenu  = CreateMenu();
    AppendMenu(hMenu,MF_POPUP,(UINT)hSousMenu,"Fichier");

    hwnd = CreateWindow("mainWinClass", "Titre", WS_OVERLAPPEDWINDOW,
                                   CW_USEDEFAULT, CW_USEDEFAULT, 400, 300,
                                                  NULL, hMenu, hinstance, NULL);
    if (!hwnd)  return FALSE;

    ShowWindow(hwnd, nCmdShow);

    while (GetMessage(&msg, NULL, 0, 0))
    {
        TranslateMessage(&msg);
        DispatchMessage(&msg);
    }
    return msg.wParam;
}

/******************************************************************************/

LRESULT CALLBACK MainWndProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
{
    switch (uMsg)
    {
        case WM_CREATE:
            RegisterHotKey(hwnd, HK_CTRL_H, MOD_CONTROL, 'H');
            return 0;

        case WM_HOTKEY:
            if(wParam==HK_CTRL_H)
               MessageBox(hwnd, "Evenement Hot Key : Ctrl H ", "Titre", MB_OK );
            return 0;

        case WM_COMMAND:
            if(LOWORD(wParam) == IDM_QUIT) PostMessage(hwnd, WM_CLOSE,0,0);
            return 0;

        case WM_DESTROY:
            UnregisterHotKey(hwnd, HK_CTRL_H);
			PostQuitMessage(0);
            return 0;

        default:
            return DefWindowProc(hwnd, uMsg, wParam, lParam);
    }
}



Ce code a été testé sous VC++, CodeBlocks(Mingw).



A vos PC.

CGi



Sommaire



C/C++
  Les pointeurs du C/C++.   Les listes chaînées.             Liste simple.             Liste triée.             Liste double.   Les arbres.   Les tas.   Le C orienté objets ?

  1 - La fenêtre principale.   2 - Contrôles et messages.   3 - Les commandes.   4 - Dialogue std.   5 - Contexte de périph.   6 - Dessiner.   7 - Les ressources.   8 - Dialogue perso.   9 - Dialogue comm.   10 - Les accélérateurs.

Assembleur
  Assembleur sous Visual C++.

C++ BUILDER
  Trucs et astuces.   Composant.   TRichEdit.   TDrawGrid.   Application MDI.   TThread.   wxWidgets.   Style Win XP.

  Première application.   Construire un menu.   Dessiner.   Sisers, Timers...   Dialogues standards.   Dialogues perso.

DotNet
  Composant C# Builder.   Contrôle WinForm.   Application MDI.

Java
  Applet java.





Copyright 2002-2016 CGi - Tous droits réservés CGi. Toutes reproduction, utilisation ou diffusion de ce document par quelque moyen que ce soit autre que pour un usage personnel doit faire l'objet d'une autorisation écrite de la part de l'auteur, propriétaire des droits intellectuels.
Les codes sources de ce document sont fournis en l'état. L'utilisateur les utilise à ses risques et périls, sans garantie d'aucune sorte de la part de l'auteur. L'auteur n'est responsable d'aucun dommage subi par l'utilisateur pouvant résulter de l'utilisation ou de la distribution des codes sources de ce document.
De la même façon, l'auteur n'est en aucun cas responsable d'une quelconque perte de revenus ou de profits, ou de données, ou de tous dommages directs ou indirects, susceptibles de survenir du fait de l'utilisation des codes sources de ce document, quand bien même l'auteur aurait été averti de la possibilité de tels dommages. L'utilisation des codes sources de ce document vaut acceptation par l'utilisateur des termes de la licence ci-dessus.

Contacter le responsable de la rubrique C