Commit e1ba4bb4 authored by Ove Kaaven's avatar Ove Kaaven Committed by Alexandre Julliard

In CopyDIBSection, use source DIB colormap instead if no palette has

been selected into the source DC, to work around some X11-imposed DIBsection implementation deficiencies.
parent c2fd62d0
...@@ -3245,7 +3245,7 @@ void X11DRV_DIB_CopyDIBSection(DC *dcSrc, DC *dcDst, ...@@ -3245,7 +3245,7 @@ void X11DRV_DIB_CopyDIBSection(DC *dcSrc, DC *dcDst,
{ {
BITMAPOBJ *bmp; BITMAPOBJ *bmp;
X11DRV_PDEVICE *physDev = (X11DRV_PDEVICE *)dcDst->physDev; X11DRV_PDEVICE *physDev = (X11DRV_PDEVICE *)dcDst->physDev;
int nColorMap = 0, *colorMap = NULL; int nColorMap = 0, *colorMap = NULL, aColorMap = FALSE;
TRACE("(%p,%p,%ld,%ld,%ld,%ld,%ld,%ld)\n", dcSrc, dcDst, TRACE("(%p,%p,%ld,%ld,%ld,%ld,%ld,%ld)\n", dcSrc, dcDst,
xSrc, ySrc, xDest, yDest, width, height); xSrc, ySrc, xDest, yDest, width, height);
...@@ -3272,17 +3272,30 @@ void X11DRV_DIB_CopyDIBSection(DC *dcSrc, DC *dcDst, ...@@ -3272,17 +3272,30 @@ void X11DRV_DIB_CopyDIBSection(DC *dcSrc, DC *dcDst,
height = bmp->bitmap.bmHeight - ySrc; height = bmp->bitmap.bmHeight - ySrc;
/* if the source bitmap is 8bpp or less, we're supposed to use the /* if the source bitmap is 8bpp or less, we're supposed to use the
* DC's palette for color conversion (not the DIB color table) */ * DC's palette for color conversion (not the DIB color table) */
if (bmp->dib->dsBm.bmBitsPixel <= 8) if (bmp->dib->dsBm.bmBitsPixel <= 8) {
colorMap = X11DRV_DIB_BuildColorMap( dcSrc, (WORD)-1, X11DRV_DIBSECTION *dib = (X11DRV_DIBSECTION *) bmp->dib;
bmp->dib->dsBm.bmBitsPixel, if ((!dcSrc->hPalette) ||
(BITMAPINFO*)&(bmp->dib->dsBmih), (dcSrc->hPalette == GetStockObject(DEFAULT_PALETTE))) {
&nColorMap ); /* HACK: no palette has been set in the source DC,
* use the DIB colormap instead - this is necessary in some
* cases since we need to do depth conversion in some places
* where real Windows can just copy data straight over */
colorMap = dib->colorMap;
nColorMap = dib->nColorMap;
} else {
colorMap = X11DRV_DIB_BuildColorMap( dcSrc, (WORD)-1,
bmp->dib->dsBm.bmBitsPixel,
(BITMAPINFO*)&(bmp->dib->dsBmih),
&nColorMap );
if (colorMap) aColorMap = TRUE;
}
}
/* perform the copy */ /* perform the copy */
X11DRV_DIB_DoCopyDIBSection(bmp, FALSE, colorMap, nColorMap, X11DRV_DIB_DoCopyDIBSection(bmp, FALSE, colorMap, nColorMap,
physDev->drawable, xSrc, ySrc, xDest, yDest, physDev->drawable, xSrc, ySrc, xDest, yDest,
width, height); width, height);
/* free color mapping */ /* free color mapping */
if (colorMap) if (aColorMap)
HeapFree(GetProcessHeap(), 0, colorMap); HeapFree(GetProcessHeap(), 0, colorMap);
} }
GDI_ReleaseObj( dcSrc->hBitmap ); GDI_ReleaseObj( dcSrc->hBitmap );
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment