Przeczytaj w języku angielskim

Udostępnij za pośrednictwem


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; 
}