Commit 8e5e588b authored by Caolan McNamara's avatar Caolan McNamara Committed by Alexandre Julliard

Added support for alternate DIBBITBLT layout.

parent 006efb35
...@@ -907,12 +907,30 @@ void WINAPI PlayMetaFileRecord16( ...@@ -907,12 +907,30 @@ void WINAPI PlayMetaFileRecord16(
case META_DIBBITBLT: case META_DIBBITBLT:
{ {
LPBITMAPINFO info = (LPBITMAPINFO) &(mr->rdParm[8]); /*In practice ive found that theres two layout for META_DIBBITBLT,
LPSTR bits = (LPSTR)info + DIB_BitmapInfoSize( info, mr->rdParm[0] ); one (the first here) is the usual one when a src dc is actually passed
StretchDIBits16(hdc,mr->rdParm[7],mr->rdParm[6],mr->rdParm[5], int, the second occurs when the src dc is passed in as NULL to
mr->rdParm[4],mr->rdParm[3],mr->rdParm[2], the creating BitBlt.
mr->rdParm[5],mr->rdParm[4],bits,info, as the second case has no dib, a size check will suffice to distinguish.
DIB_RGB_COLORS,MAKELONG(mr->rdParm[0],mr->rdParm[1]));
Caolan.McNamara@ul.ie
*/
if (mr->rdSize > 12)
{
LPBITMAPINFO info = (LPBITMAPINFO) &(mr->rdParm[8]);
LPSTR bits = (LPSTR)info + DIB_BitmapInfoSize( info, mr->rdParm[0] );
StretchDIBits16(hdc,mr->rdParm[7],mr->rdParm[6],mr->rdParm[5],
mr->rdParm[4],mr->rdParm[3],mr->rdParm[2],
mr->rdParm[5],mr->rdParm[4],bits,info,
DIB_RGB_COLORS,MAKELONG(mr->rdParm[0],mr->rdParm[1]));
}
else /*equivalent to a PatBlt*/
{
PatBlt16(hdc, mr->rdParm[8], mr->rdParm[7],
mr->rdParm[6], mr->rdParm[5],
MAKELONG(*(mr->rdParm), *(mr->rdParm + 1)));
}
} }
break; break;
......
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