ใช้ปุ่มวาดเจ้า

หน้าต่างหลักของปุ่มวาดเจ้าตัวตอบสนองต่อข้อความอย่างน้อยสามปุ่มโดยทั่วไป: 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); 
} 
 

Index