Commit 48455b36 authored by Lionel Ulmer's avatar Lionel Ulmer Committed by Alexandre Julliard

Upgrade also 15bpp to 16bpp surfaces.

parent 34899975
...@@ -549,19 +549,22 @@ HRESULT common_off_screen_CreateSurface( ...@@ -549,19 +549,22 @@ HRESULT common_off_screen_CreateSurface(
} }
bpp = GET_BPP(lpdsf->s.surface_desc); bpp = GET_BPP(lpdsf->s.surface_desc);
if (bpp != PFGET_BPP(This->d->directdraw_pixelformat)) { /* When the application is requesting a 24 bpp surface and the Direct Draw bpp
/* When the application is requesting a 24 bpp surface and the Direct Draw bpp is set to 32, we 'upgrade' the requested bpp to 32 to make the blit faster
is set to 32, we 'upgrade' the requested bpp to 32 to make the blit faster from off-screen surface to visible surfaces.
from off-screen surface to visible surfaces.
This can also happen with 15 / 16 bpp.
With this, Windows Media Player works in 32 bpp mode.
Lionel */ With this, Windows Media Player works in 32 bpp mode.
if ((bpp == 3) && (PFGET_BPP(This->d->directdraw_pixelformat) == 4)) { Lionel
TRACE("Warning: 'upgrading' requested 24 bpp format to 32 bpp for efficiencies reasons\n"); */
TRACE(" some applications may have problems with it.\n"); if (((bpp == 3) && (PFGET_BPP(This->d->directdraw_pixelformat) == 4)) ||
bpp = PFGET_BPP(This->d->directdraw_pixelformat); ((bpp == 2) && (PFGET_BPP(This->d->directdraw_pixelformat) == 2) &&
lpdsf->s.surface_desc.ddpfPixelFormat = This->d->directdraw_pixelformat; (lpdsf->s.surface_desc.ddpfPixelFormat.u1.dwRBitMask != This->d->directdraw_pixelformat.u1.dwRBitMask))) {
} TRACE("Warning: 'upgrading' requested pixel format to screen pixel format for blit efficiency\n");
TRACE(" some applications may have problems with it.\n");
bpp = PFGET_BPP(This->d->directdraw_pixelformat);
lpdsf->s.surface_desc.ddpfPixelFormat = This->d->directdraw_pixelformat;
} }
} }
......
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