gdi32: Add the ability to track whether we should defer to the graphics driver.
This commit is contained in:
parent
ed23e3de5c
commit
842d49939d
|
@ -90,12 +90,12 @@ static BOOL init_dib(dib_info *dib, const BITMAPINFOHEADER *bi, const DWORD *bit
|
|||
switch(dib->bit_count)
|
||||
{
|
||||
case 32:
|
||||
init_bit_fields(dib, bit_fields);
|
||||
if(dib->red_mask == 0xff0000 && dib->green_mask == 0x00ff00 && dib->blue_mask == 0x0000ff)
|
||||
dib->funcs = &funcs_8888;
|
||||
else
|
||||
dib->funcs = &funcs_32;
|
||||
break;
|
||||
init_bit_fields(dib, bit_fields);
|
||||
if(dib->red_mask == 0xff0000 && dib->green_mask == 0x00ff00 && dib->blue_mask == 0x0000ff)
|
||||
dib->funcs = &funcs_8888;
|
||||
else
|
||||
dib->funcs = &funcs_32;
|
||||
break;
|
||||
|
||||
default:
|
||||
TRACE("bpp %d not supported, will forward to graphics driver.\n", dib->bit_count);
|
||||
|
@ -118,7 +118,10 @@ static HBITMAP CDECL dibdrv_SelectBitmap( PHYSDEV dev, HBITMAP bitmap )
|
|||
if (!bmp) return 0;
|
||||
assert(bmp->dib);
|
||||
|
||||
init_dib(&pdev->dib, &bmp->dib->dsBmih, bmp->dib->dsBitfields, bmp->dib->dsBm.bmBits);
|
||||
pdev->defer = 0;
|
||||
|
||||
if(!init_dib(&pdev->dib, &bmp->dib->dsBmih, bmp->dib->dsBitfields, bmp->dib->dsBm.bmBits))
|
||||
pdev->defer |= DEFER_FORMAT;
|
||||
|
||||
GDI_ReleaseObj( bitmap );
|
||||
|
||||
|
|
|
@ -58,5 +58,18 @@ HPEN CDECL dibdrv_SelectPen( PHYSDEV dev, HPEN hpen )
|
|||
|
||||
pdev->pen_color = pdev->dib.funcs->colorref_to_pixel(&pdev->dib, logpen.lopnColor);
|
||||
|
||||
pdev->defer |= DEFER_PEN;
|
||||
|
||||
switch(logpen.lopnStyle & PS_STYLE_MASK)
|
||||
{
|
||||
case PS_SOLID:
|
||||
if(logpen.lopnStyle & PS_GEOMETRIC) break;
|
||||
if(logpen.lopnWidth.x > 1) break;
|
||||
pdev->defer &= ~DEFER_PEN;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
return next->funcs->pSelectPen( next, hpen );
|
||||
}
|
||||
|
|
|
@ -97,10 +97,15 @@ typedef struct dibdrv_physdev
|
|||
struct gdi_physdev dev;
|
||||
dib_info dib;
|
||||
|
||||
DWORD defer;
|
||||
|
||||
/* pen */
|
||||
DWORD pen_color;
|
||||
} dibdrv_physdev;
|
||||
|
||||
#define DEFER_FORMAT 1
|
||||
#define DEFER_PEN 2
|
||||
|
||||
typedef struct tagDC_FUNCS
|
||||
{
|
||||
INT (CDECL *pAbortDoc)(PHYSDEV);
|
||||
|
|
Loading…
Reference in New Issue