Partager via


Comment créer des barres de défilement

Lorsque vous créez une fenêtre superposée, contextuelle ou enfant, vous pouvez ajouter des barres de défilement standard à l’aide de la fonction CreateWindowEx et en spécifiant WS_HSCROLL, WS_VSCROLL ou les deux styles.

Bon à savoir

Technologies

Prérequis

  • C/C++
  • Programmation de l’interface utilisateur Windows

Instructions

Créer une barre de défilement

L’exemple suivant crée une fenêtre avec des barres de défilement horizontales et verticales standard.

    hwnd = CreateWindowEx( 
        0,                     // no extended styles 
        g_szWindowClass,       // global string containing name of window class
        g_szTitle,             // global string containing title bar text 
        WS_OVERLAPPEDWINDOW |  
            WS_HSCROLL | WS_VSCROLL, // window styles 
        CW_USEDEFAULT,         // default horizontal position 
        CW_USEDEFAULT,         // default vertical position 
        CW_USEDEFAULT,         // default width 
        CW_USEDEFAULT,         // default height 
        (HWND) NULL,           // no parent for overlapped windows 
        (HMENU) NULL,          // use the window class menu 
        g_hInst,               // global instance handle  
        (PVOID) NULL           // pointer not needed 
    ); 

Pour traiter les messages de barre de défilement pour ces barres de défilement, vous devez inclure le code approprié dans la procédure de fenêtre main.

Vous pouvez utiliser la fonction CreateWindowEx pour créer une barre de défilement en spécifiant la classe de fenêtre SCROLLBAR. Cela crée une barre de défilement horizontale ou verticale, selon que SBS_HORZ ou SBS_VERT est spécifié comme style de fenêtre. La taille de la barre de défilement et sa position par rapport à sa fenêtre parente peuvent également être spécifiées.

L’exemple suivant crée une barre de défilement horizontale qui est positionnée le long du bas de la zone cliente de la fenêtre parente.

// Description:
//   Creates a horizontal scroll bar along the bottom of the parent 
//   window's area.
// Parameters:
//   hwndParent - handle to the parent window.
//   sbHeight - height, in pixels, of the scroll bar.
// Returns:
//   The handle to the scroll bar.
HWND CreateAHorizontalScrollBar(HWND hwndParent, int sbHeight)
{
    RECT rect;

    // Get the dimensions of the parent window's client area;
    if (!GetClientRect(hwndParent, &rect))
        return NULL;

    // Create the scroll bar.
    return (CreateWindowEx( 
            0,                      // no extended styles 
            L"SCROLLBAR",           // scroll bar control class 
            (PTSTR) NULL,           // no window text 
            WS_CHILD | WS_VISIBLE   // window styles  
                | SBS_HORZ,         // horizontal scroll bar style 
            rect.left,              // horizontal position 
            rect.bottom - sbHeight, // vertical position 
            rect.right,             // width of the scroll bar 
            sbHeight,               // height of the scroll bar
            hwndParent,             // handle to main window 
            (HMENU) NULL,           // no menu 
            g_hInst,                // instance owning this window 
            (PVOID) NULL            // pointer not needed 
        )); 
}

Utilisation des barres de défilement

Démonstration des contrôles communs Windows (CppWindowsCommonControls)