Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Při vytváření překrytého, vyskakovacího nebo podřízeného okna můžete přidat standardní posuvníky pomocí funkce CreateWindowEx a specifikováním stylů WS_HSCROLL, WS_VSCROLL nebo obou.
Co potřebujete vědět
Technologie
Požadavky
- C/C++
- Programování uživatelského rozhraní systému Windows
Instrukce
Vytvoření posuvníku
Následující příklad vytvoří okno se standardními vodorovnými a svislými posuvníky.
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
);
Chcete-li zpracovat zprávy posuvníku pro tyto posuvníky, musíte do hlavního okna zahrnout odpovídající kód.
Pomocí funkce CreateWindowEx můžete vytvořit posuvník zadáním třídy okna SCROLLBAR. Tím se vytvoří vodorovný nebo svislý posuvník v závislosti na tom, jestli je jako styl okna zadán SBS_HORZ nebo SBS_VERT. Můžete také zadat velikost posuvníku a jeho umístění vzhledem k nadřazeným oknem.
Následující příklad vytvoří vodorovný posuvník umístěný v dolní části klientské oblasti nadřazeného okna.
// 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
));
}
Související témata