Объявление клиентской области недействительной
Система не является единственным источником WM_PAINT сообщений. Функция InvalidateRect или InvalidateRgn может косвенно создавать сообщения WM_PAINT для окон. Эти функции помечают всю или часть клиентской области как невалидные (подлежащие перерисовке).
В следующем примере процедура окна отменяет всю клиентская область при обработке сообщений WM_CHAR. Это позволяет пользователю изменять фигуру, вводя число и просматривая результаты; эти результаты вырисовываются, как только в очереди сообщений приложения нет других сообщений.
RECT rc;
POINT aptPentagon[6] = {50,2, 98,35, 79,90, 21,90, 2,35, 50,2},
aptHexagon[7] = {50,2, 93,25, 93,75, 50,98, 7,75, 7,25, 50,2};
POINT *ppt = aptPentagon;
int cpt = 6;
.
.
.
case WM_CHAR:
switch (wParam)
{
case '5':
ppt = aptPentagon;
cpt = 6;
break;
case '6':
ppt = aptHexagon;
cpt = 7;
break;
}
InvalidateRect(hwnd, NULL, TRUE);
return 0L;
case WM_PAINT:
hdc = BeginPaint(hwnd, &ps);
GetClientRect(hwnd, &rc);
SetMapMode(hdc, MM_ANISOTROPIC);
SetWindowExtEx(hdc, 100, 100, NULL);
SetViewportExtEx(hdc, rc.right, rc.bottom, NULL);
Polyline(hdc, ppt, cpt);
EndPaint(hwnd, &ps);
return 0L;
В этом примере аргумент NULL, используемый InvalidateRect, указывает на всю область клиента; аргумент TRUE приводит к очистке фона. Если вы не хотите, чтобы приложение ожидало, пока очередь его сообщений не освободится от других сообщений, используйте функцию UpdateWindow, чтобы немедленно отправить сообщение WM_PAINT. Если в клиентской области есть недопустимая часть, UpdateWindow отправляет сообщение WM_PAINT для указанного окна непосредственно в процедуру окна.