gdi32: Ignore the alpha channel for blits to DDBs too.

Signed-off-by: Huw Davies <huw@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
diff --git a/dlls/gdi32/bitblt.c b/dlls/gdi32/bitblt.c
index 1b057f7..0f21283 100644
--- a/dlls/gdi32/bitblt.c
+++ b/dlls/gdi32/bitblt.c
@@ -843,6 +843,7 @@
     COLORREF oldBackground;
     COLORREF oldForeground;
     int oldStretchMode;
+    DIBSECTION dib;
 
     if(widthDest < 0 || heightDest < 0 || widthSrc < 0 || heightSrc < 0) {
         TRACE("Cannot mirror\n");
@@ -857,9 +858,11 @@
     if(oldStretchMode == BLACKONWHITE || oldStretchMode == WHITEONBLACK)
         SetStretchBltMode(hdcSrc, COLORONCOLOR);
     hdcWork = CreateCompatibleDC(hdcDest);
-    if (GetObjectType( hdcDest ) != OBJ_MEMDC && GetDeviceCaps( hdcDest, BITSPIXEL ) == 32)
+    if ((GetObjectType( hdcDest ) != OBJ_MEMDC ||
+         GetObjectW( GetCurrentObject( hdcDest, OBJ_BITMAP ), sizeof(dib), &dib ) == sizeof(BITMAP)) &&
+        GetDeviceCaps( hdcDest, BITSPIXEL ) == 32)
     {
-        /* screen DCs are not supposed to have an alpha channel, so use a 24-bpp bitmap as copy */
+        /* screen DCs or DDBs are not supposed to have an alpha channel, so use a 24-bpp bitmap as copy */
         BITMAPINFO info;
         info.bmiHeader.biSize = sizeof(info.bmiHeader);
         info.bmiHeader.biWidth = widthDest;