C++ 我的菜单有两个缓冲区

C++ 我的菜单有两个缓冲区,c++,visual-c++,native-code,C++,Visual C++,Native Code,我使用下面的代码在我的应用程序中实现了双缓冲。 在wards之后,我发现我的子窗口(即buttoms)没有像正常窗口那样设置动画,因此我将WS_EX_COMPOSITED添加到父窗口中,子窗口现在可以正确设置动画。但是,在添加WS_EX_COMPOSITED后,从我的资源创建的“我的菜单”为黑色,无法正确显示 那么,如何将双缓冲添加到我的顶部菜单 MainWinHwnd = CreateWindowEx(WS_EX_COMPOSITED, MainWinClassName, MainWinTit

我使用下面的代码在我的应用程序中实现了双缓冲。 在wards之后,我发现我的子窗口(即buttoms)没有像正常窗口那样设置动画,因此我将WS_EX_COMPOSITED添加到父窗口中,子窗口现在可以正确设置动画。但是,在添加WS_EX_COMPOSITED后,从我的资源创建的“我的菜单”为黑色,无法正确显示

那么,如何将双缓冲添加到我的顶部菜单

MainWinHwnd = CreateWindowEx(WS_EX_COMPOSITED, MainWinClassName, MainWinTitle,
WS_VISIBLE|WS_BORDER|WS_SYSMENU|WS_MINIMIZEBOX|WS_MAXIMIZEBOX|WS_SIZEBOX|WS_CLIPCHILDREN,
        NULL, NULL, 609, 440, NULL, NULL, hInstance, NULL);
    if (!MainWinHwnd) return FALSE;

case WM_PAINT:
    {
        RECT WinRt;
        RECT TxtRt;
        HFONT TxtFont = NULL;
        SIZE TxtSize;

        HDC WinDC = GetDC(hWnd);
        GetClientRect(hWnd, &WinRt);
        HDC WinBuffer = CreateCompatibleDC(WinDC);
        HBITMAP BitBuffer = CreateCompatibleBitmap(WinDC, WinRt.right, WinRt.bottom);
        SelectObject(WinBuffer, BitBuffer);

        FillRect(WinBuffer, &WinRt, (HBRUSH) (COLOR_BTNFACE + 1));

        SetBkColor(WinBuffer, GetSysColor((COLOR_BTNFACE)));

        DrawThemeBackground(ButtonThemeData, WinBuffer, BP_GROUPBOX, GBS_NORMAL, &GroupOptionBox, NULL);
        DrawThemeBackground(DragDropThemeData, WinBuffer, RP_GRIPPER, 0, &DragDropItem, NULL);

        for (DWORD I = 0; I < sizeof(MainWinLabels) / sizeof(CustomLabel); I++)
        {
            if (MainWinLabels[I].Font == NULL)
            {
                TxtFont = CreateFontA(MainWinLabels[I].cFontHeight, NULL, NULL, NULL, FW_DONTCARE,
                    MainWinLabels[I].cFontItalic, MainWinLabels[I].cFontUnderline,
                    MainWinLabels[I].cFontStrikeOut, DEFAULT_CHARSET, OUT_DEFAULT_PRECIS, CLIP_DEFAULT_PRECIS,
                    MainWinLabels[I].cFontQuality, DEFAULT_PITCH, MainWinLabels[I].cFontFaceName);
                if (TxtFont == NULL) continue;
                SelectObject(WinBuffer, TxtFont);
            }
            else SelectObject(WinBuffer, *MainWinLabels[I].Font);

            SetTextColor(WinBuffer, MainWinLabels[I].Color);

            TxtRt.left = MainWinLabels[I].X;
            TxtRt.top = MainWinLabels[I].Y;

            DrawTextA(WinBuffer, MainWinLabels[I].Text, strlen(MainWinLabels[I].Text), &TxtRt,
                DT_LEFT|DT_SINGLELINE|DT_NOCLIP);

            GetTextExtentPoint32A(WinBuffer, MainWinLabels[I].Text, strlen(MainWinLabels[I].Text), &TxtSize);
            MainWinLabels[I].Width = TxtSize.cx;
            MainWinLabels[I].Height = TxtSize.cy;

            if (TxtFont != NULL) DeleteObject(TxtFont);
        }

        BitBlt(WinDC, 0, 0, WinRt.right, WinRt.bottom, WinBuffer, 0, 0, SRCCOPY);

        ReleaseDC(hWnd, WinDC);
        DeleteObject(BitBuffer);
        DeleteDC(WinBuffer);

        break;
    }
解决方案:

不要使用WS_EX_COMPOSITED。 使用BeginPainthwnd和EndPainthwnd,而不是使用GetDChWnd和&ps