Rysowanie w obszarze aplikacji
Używa się funkcji BeginPaint i EndPaint do przygotowania i ukończenia rysunku w obszarze klienta. BeginPaint zwraca uchwyt do kontekstu wyświetlania używanego do rysowania w obszarze roboczym klienta; EndPaint kończy żądanie malowania i zwalnia kontekst wyświetlania.
W poniższym przykładzie procedura okna zapisuje komunikat "Hello, Windows!" w obszarze klienta. Aby upewnić się, że ciąg jest widoczny po pierwszym utworzeniu okna, funkcja WinMain wywołuje UpdateWindow natychmiast po utworzeniu i wyświetleniu okna. Powoduje to natychmiastowe wysłanie komunikatu WM_PAINT do procedury okna.
LRESULT APIENTRY WndProc(HWND hwnd, UINT message, WPARAM wParam, LPARAM lParam)
{
PAINTSTRUCT ps;
HDC hdc;
switch (message)
{
case WM_PAINT:
hdc = BeginPaint(hwnd, &ps);
TextOut(hdc, 0, 0, "Hello, Windows!", 15);
EndPaint(hwnd, &ps);
return 0L;
// Process other messages.
}
}
int APIENTRY WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nCmdShow)
{
HWND hwnd;
hwnd = CreateWindowEx(
// parameters
);
ShowWindow(hwnd, SW_SHOW);
UpdateWindow(hwnd);
return msg.wParam;
}