Görgetősávok létrehozása
Átfedésben lévő, előugró vagy gyermekablak létrehozásakor a CreateWindowEx függvénnyel és WS_HSCROLL, WS_VSCROLL vagy mindkét stílus megadásával adhat hozzá normál görgetősávokat.
Amit tudnia kell
Technológiák
Előfeltételek
- C/C++
- Windows felhasználói felület programozása
Előírás
Görgetősáv létrehozása
Az alábbi példa egy szabványos vízszintes és függőleges görgetősávokkal rendelkező ablakot hoz létre.
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
);
A görgetősávok üzeneteinek feldolgozásához a főablak eljárásában meg kell adnia a megfelelő kódot.
A SCROLLBAR ablakosztály megadásával a CreateWindowEx függvénnyel hozhat létre görgetősávot. Ez egy vízszintes vagy függőleges görgetősávot hoz létre attól függően, hogy SBS_HORZ vagy SBS_VERT van-e megadva ablakstílusként. A görgetősáv mérete és a szülőablakhoz viszonyított helyzete is megadható.
Az alábbi példa egy vízszintes görgetősávot hoz létre, amely a szülőablak ügyfélterületének alján helyezkedik el.
// 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
));
}
Kapcsolódó témakörök