Батько вікно кнопки власник звертається зазвичай відповідає на принаймні три повідомлення для кнопки: WM_INITDIALOG, WM_COMMANDі WM_DRAWITEM. Це не є необхідним для обробки повідомлення WM_MEASUREITEM для власника звертається кнопки.
Коли слід малювати кнопки власник звертається, система надішле батьківського вікно WM_DRAWITEM повідомлення, чиї lParam вказує на DRAWITEMSTRUCT структури. Використовувати цю структуру з усіх елементів керування власник звертається, щоб забезпечити застосування з інформацією, що він вимагає, щоб намалювати елемент керування. ItemAction і itemState члени DRAWITEMSTRUCT структура визначити, як малювати кнопки звертається власник.
Наступний приклад показує, як обробляти повідомлення WM_INITDIALOG, WM_DRAWITEM і WM_COMMAND для власника звертається кнопки. Цей приклад демонструє, як зробити один з двох крапкові малюнки для елемента керування, залежно від того, чи вибраний елемент керування. Ви б зазвичай використовують параметр wParam WM_DRAWITEM повідомлення можна ідентифікувати елемент керування; у цьому прикладі вважається лише один елемент керування.
BOOL CALLBACK OwnDrawProc(HWND hDlg, UINT message, WPARAM wParam,
LPARAM lParam)
{
HDC hdcMem;
LPDRAWITEMSTRUCT lpdis;
switch (message)
{
case WM_INITDIALOG:
// hinst, hbm1 and hbm2 are defined globally.
hbm1 = LoadBitmap((HANDLE) hinst, "OwnBit1");
hbm2 = LoadBitmap((HANDLE) hinst, "OwnBit2");
return TRUE;
case WM_DRAWITEM:
lpdis = (LPDRAWITEMSTRUCT) lParam;
hdcMem = CreateCompatibleDC(lpdis->hDC);
if (lpdis->itemState & ODS_SELECTED) // if selected
SelectObject(hdcMem, hbm2);
else
SelectObject(hdcMem, hbm1);
// Destination
StretchBlt(
lpdis->hDC, // destination DC
lpdis->rcItem.left, // x upper left
lpdis->rcItem.top, // y upper left
// The next two lines specify the width and
// height.
lpdis->rcItem.right - lpdis->rcItem.left,
lpdis->rcItem.bottom - lpdis->rcItem.top,
hdcMem, // source device context
0, 0, // x and y upper left
32, // source bitmap width
32, // source bitmap height
SRCCOPY); // raster operation
DeleteDC(hdcMem);
return TRUE;
case WM_COMMAND:
if (wParam == IDOK
|| wParam == IDCANCEL)
{
EndDialog(hDlg, TRUE);
return TRUE;
}
if (HIWORD(wParam) == BN_CLICKED)
{
switch (LOWORD(wParam))
{
case IDC_OWNERDRAW:
// application-defined processing
break;
}
}
break;
case WM_DESTROY:
DeleteObject(hbm1); // delete bitmaps
DeleteObject(hbm2);
break;
}
return FALSE;
UNREFERENCED_PARAMETER(lParam);
}