mirror of
https://github.com/reactos/reactos.git
synced 2024-10-31 03:48:17 +00:00
Note SURFGDI structure change --- added new DIB function called DIB_StretchBlt().
StretchBlt() skeleton is now working as it should (w/o some clipping, stretching modes set, but all this is marked either as FIXME or TODO). svn path=/trunk/; revision=6914
This commit is contained in:
parent
c1eb7e7ef1
commit
2a9609d601
|
@ -16,7 +16,7 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
*/
|
*/
|
||||||
/* $Id: bitblt.c,v 1.30 2003/12/08 11:11:11 fireball Exp $
|
/* $Id: bitblt.c,v 1.31 2003/12/08 18:07:56 fireball Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -57,6 +57,17 @@ typedef BOOLEAN STDCALL (*PBLTRECTFUNC)(SURFOBJ* OutputObj,
|
||||||
BRUSHOBJ* Brush,
|
BRUSHOBJ* Brush,
|
||||||
POINTL* BrushOrigin,
|
POINTL* BrushOrigin,
|
||||||
ROP4 Rop4);
|
ROP4 Rop4);
|
||||||
|
typedef BOOLEAN STDCALL (*PSTRETCHRECTFUNC)(SURFOBJ* OutputObj,
|
||||||
|
SURFGDI* OutputGDI,
|
||||||
|
SURFOBJ* InputObj,
|
||||||
|
SURFGDI* InputGDI,
|
||||||
|
SURFOBJ* Mask,
|
||||||
|
XLATEOBJ* ColorTranslation,
|
||||||
|
RECTL* OutputRect,
|
||||||
|
RECTL* InputRect,
|
||||||
|
POINTL* MaskOrigin,
|
||||||
|
POINTL* BrushOrigin,
|
||||||
|
ULONG Mode);
|
||||||
|
|
||||||
BOOL STDCALL EngIntersectRect(RECTL* prcDst, RECTL* prcSrc1, RECTL* prcSrc2)
|
BOOL STDCALL EngIntersectRect(RECTL* prcDst, RECTL* prcSrc1, RECTL* prcSrc2)
|
||||||
{
|
{
|
||||||
|
@ -472,6 +483,230 @@ IntEngBitBlt(SURFOBJ *DestObj,
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static BOOLEAN STDCALL
|
||||||
|
CallDibStretchBlt(SURFOBJ* OutputObj,
|
||||||
|
SURFGDI* OutputGDI,
|
||||||
|
SURFOBJ* InputObj,
|
||||||
|
SURFGDI* InputGDI,
|
||||||
|
SURFOBJ* Mask,
|
||||||
|
XLATEOBJ* ColorTranslation,
|
||||||
|
RECTL* OutputRect,
|
||||||
|
RECTL* InputRect,
|
||||||
|
POINTL* MaskOrigin,
|
||||||
|
POINTL* BrushOrigin,
|
||||||
|
ULONG Mode)
|
||||||
|
{
|
||||||
|
DPRINT1("CallDibStretchBlt() called...");
|
||||||
|
return OutputGDI->DIB_StretchBlt(OutputObj, InputObj, OutputGDI, InputGDI, OutputRect, InputRect, MaskOrigin, BrushOrigin, ColorTranslation, Mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
BOOL
|
||||||
|
STDCALL
|
||||||
|
EngStretchBlt(
|
||||||
|
IN SURFOBJ *DestObj,
|
||||||
|
IN SURFOBJ *SourceObj,
|
||||||
|
IN SURFOBJ *Mask,
|
||||||
|
IN CLIPOBJ *ClipRegion,
|
||||||
|
IN XLATEOBJ *ColorTranslation,
|
||||||
|
IN COLORADJUSTMENT *pca,
|
||||||
|
IN POINTL *BrushOrigin,
|
||||||
|
IN RECTL *prclDest,
|
||||||
|
IN RECTL *prclSrc,
|
||||||
|
IN POINTL *MaskOrigin,
|
||||||
|
IN ULONG Mode
|
||||||
|
)
|
||||||
|
{
|
||||||
|
// www.osr.com/ddk/graphics/gdifncs_0bs7.htm
|
||||||
|
|
||||||
|
BYTE clippingType;
|
||||||
|
RECTL CombinedRect;
|
||||||
|
// RECT_ENUM RectEnum;
|
||||||
|
// BOOL EnumMore;
|
||||||
|
SURFGDI* OutputGDI;
|
||||||
|
SURFGDI* InputGDI;
|
||||||
|
POINTL InputPoint;
|
||||||
|
RECTL InputRect;
|
||||||
|
RECTL OutputRect;
|
||||||
|
POINTL Translate;
|
||||||
|
INTENG_ENTER_LEAVE EnterLeaveSource;
|
||||||
|
INTENG_ENTER_LEAVE EnterLeaveDest;
|
||||||
|
SURFOBJ* InputObj;
|
||||||
|
SURFOBJ* OutputObj;
|
||||||
|
PSTRETCHRECTFUNC BltRectFunc;
|
||||||
|
BOOLEAN Ret;
|
||||||
|
RECTL ClipRect;
|
||||||
|
// unsigned i;
|
||||||
|
POINTL Pt;
|
||||||
|
// ULONG Direction;
|
||||||
|
|
||||||
|
InputRect.left = prclSrc->left;
|
||||||
|
InputRect.right = prclSrc->right;
|
||||||
|
InputRect.top = prclSrc->top;
|
||||||
|
InputRect.bottom = prclSrc->bottom;
|
||||||
|
|
||||||
|
if (! IntEngEnter(&EnterLeaveSource, SourceObj, &InputRect, TRUE, &Translate, &InputObj))
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
InputPoint.x = InputRect.left + Translate.x;
|
||||||
|
InputPoint.y = InputRect.top + Translate.y;
|
||||||
|
|
||||||
|
if (NULL != InputObj)
|
||||||
|
{
|
||||||
|
InputGDI = (SURFGDI*) AccessInternalObjectFromUserObject(InputObj);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
InputGDI = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
OutputRect = *prclDest;
|
||||||
|
if (NULL != ClipRegion)
|
||||||
|
{
|
||||||
|
if (OutputRect.left < ClipRegion->rclBounds.left)
|
||||||
|
{
|
||||||
|
InputRect.left += ClipRegion->rclBounds.left - OutputRect.left;
|
||||||
|
InputPoint.x += ClipRegion->rclBounds.left - OutputRect.left;
|
||||||
|
OutputRect.left = ClipRegion->rclBounds.left;
|
||||||
|
}
|
||||||
|
if (ClipRegion->rclBounds.right < OutputRect.right)
|
||||||
|
{
|
||||||
|
InputRect.right -= OutputRect.right - ClipRegion->rclBounds.right;
|
||||||
|
OutputRect.right = ClipRegion->rclBounds.right;
|
||||||
|
}
|
||||||
|
if (OutputRect.top < ClipRegion->rclBounds.top)
|
||||||
|
{
|
||||||
|
InputRect.top += ClipRegion->rclBounds.top - OutputRect.top;
|
||||||
|
InputPoint.y += ClipRegion->rclBounds.top - OutputRect.top;
|
||||||
|
OutputRect.top = ClipRegion->rclBounds.top;
|
||||||
|
}
|
||||||
|
if (ClipRegion->rclBounds.bottom < OutputRect.bottom)
|
||||||
|
{
|
||||||
|
InputRect.bottom -= OutputRect.bottom - ClipRegion->rclBounds.bottom;
|
||||||
|
OutputRect.bottom = ClipRegion->rclBounds.bottom;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Check for degenerate case: if height or width of OutputRect is 0 pixels there's
|
||||||
|
nothing to do */
|
||||||
|
if (OutputRect.right <= OutputRect.left || OutputRect.bottom <= OutputRect.top)
|
||||||
|
{
|
||||||
|
IntEngLeave(&EnterLeaveSource);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (! IntEngEnter(&EnterLeaveDest, DestObj, &OutputRect, FALSE, &Translate, &OutputObj))
|
||||||
|
{
|
||||||
|
IntEngLeave(&EnterLeaveSource);
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
OutputRect.left = prclDest->left + Translate.x;
|
||||||
|
OutputRect.right = prclDest->right + Translate.x;
|
||||||
|
OutputRect.top = prclDest->top + Translate.y;
|
||||||
|
OutputRect.bottom = prclDest->bottom + Translate.y;
|
||||||
|
|
||||||
|
if (NULL != OutputObj)
|
||||||
|
{
|
||||||
|
OutputGDI = (SURFGDI*)AccessInternalObjectFromUserObject(OutputObj);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Determine clipping type
|
||||||
|
if (ClipRegion == (CLIPOBJ *) NULL)
|
||||||
|
{
|
||||||
|
clippingType = DC_TRIVIAL;
|
||||||
|
} else {
|
||||||
|
clippingType = ClipRegion->iDComplexity;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Mask != NULL)//(0xaacc == Rop4)
|
||||||
|
{
|
||||||
|
//BltRectFunc = BltMask;
|
||||||
|
DPRINT("EngStretchBlt isn't capable of handling mask yet.\n");
|
||||||
|
IntEngLeave(&EnterLeaveDest);
|
||||||
|
IntEngLeave(&EnterLeaveSource);
|
||||||
|
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
BltRectFunc = CallDibStretchBlt;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
switch(clippingType)
|
||||||
|
{
|
||||||
|
case DC_TRIVIAL:
|
||||||
|
Ret = (*BltRectFunc)(OutputObj, OutputGDI, InputObj, InputGDI, Mask, ColorTranslation,
|
||||||
|
&OutputRect, &InputRect, MaskOrigin, BrushOrigin, Mode);
|
||||||
|
break;
|
||||||
|
case DC_RECT:
|
||||||
|
// Clip the blt to the clip rectangle
|
||||||
|
ClipRect.left = ClipRegion->rclBounds.left + Translate.x;
|
||||||
|
ClipRect.right = ClipRegion->rclBounds.right + Translate.x;
|
||||||
|
ClipRect.top = ClipRegion->rclBounds.top + Translate.y;
|
||||||
|
ClipRect.bottom = ClipRegion->rclBounds.bottom + Translate.y;
|
||||||
|
EngIntersectRect(&CombinedRect, &OutputRect, &ClipRect);
|
||||||
|
Pt.x = InputPoint.x + CombinedRect.left - OutputRect.left;
|
||||||
|
Pt.y = InputPoint.y + CombinedRect.top - OutputRect.top;
|
||||||
|
Ret = (*BltRectFunc)(OutputObj, OutputGDI, InputObj, InputGDI, Mask, ColorTranslation,
|
||||||
|
&OutputRect, &InputRect, MaskOrigin, BrushOrigin, Mode);
|
||||||
|
//Ret = (*BltRectFunc)(OutputObj, OutputGDI, InputObj, InputGDI, Mask, ColorTranslation,
|
||||||
|
// &CombinedRect, &Pt, MaskOrigin, Brush, BrushOrigin, Rop4);
|
||||||
|
DPRINT("EngStretchBlt() doesn't support DC_RECT clipping yet, so blitting w/o clip.\n");
|
||||||
|
break;
|
||||||
|
// TODO: Complex clipping
|
||||||
|
/*
|
||||||
|
case DC_COMPLEX:
|
||||||
|
Ret = TRUE;
|
||||||
|
if (OutputObj == InputObj)
|
||||||
|
{
|
||||||
|
if (OutputRect.top < InputPoint.y)
|
||||||
|
{
|
||||||
|
Direction = OutputRect.left < InputPoint.x ? CD_RIGHTDOWN : CD_LEFTDOWN;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Direction = OutputRect.left < InputPoint.x ? CD_RIGHTUP : CD_LEFTUP;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Direction = CD_ANY;
|
||||||
|
}
|
||||||
|
CLIPOBJ_cEnumStart(ClipRegion, FALSE, CT_RECTANGLES, Direction, ENUM_RECT_LIMIT);
|
||||||
|
do
|
||||||
|
{
|
||||||
|
EnumMore = CLIPOBJ_bEnum(ClipRegion,(ULONG) sizeof(RectEnum), (PVOID) &RectEnum);
|
||||||
|
|
||||||
|
for (i = 0; i < RectEnum.c; i++)
|
||||||
|
{
|
||||||
|
ClipRect.left = RectEnum.arcl[i].left + Translate.x;
|
||||||
|
ClipRect.right = RectEnum.arcl[i].right + Translate.x;
|
||||||
|
ClipRect.top = RectEnum.arcl[i].top + Translate.y;
|
||||||
|
ClipRect.bottom = RectEnum.arcl[i].bottom + Translate.y;
|
||||||
|
EngIntersectRect(&CombinedRect, &OutputRect, &ClipRect);
|
||||||
|
Pt.x = InputPoint.x + CombinedRect.left - OutputRect.left;
|
||||||
|
Pt.y = InputPoint.y + CombinedRect.top - OutputRect.top;
|
||||||
|
Ret = (*BltRectFunc)(OutputObj, OutputGDI, InputObj, InputGDI, Mask, ColorTranslation,
|
||||||
|
&CombinedRect, &Pt, MaskOrigin, Brush, BrushOrigin, Rop4) &&
|
||||||
|
Ret;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
while(EnumMore);
|
||||||
|
break;
|
||||||
|
*/
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
IntEngLeave(&EnterLeaveDest);
|
||||||
|
IntEngLeave(&EnterLeaveSource);
|
||||||
|
|
||||||
|
return Ret;
|
||||||
|
}
|
||||||
|
|
||||||
BOOL STDCALL
|
BOOL STDCALL
|
||||||
IntEngStretchBlt(SURFOBJ *DestObj,
|
IntEngStretchBlt(SURFOBJ *DestObj,
|
||||||
SURFOBJ *SourceObj,
|
SURFOBJ *SourceObj,
|
||||||
|
@ -541,30 +776,18 @@ IntEngStretchBlt(SURFOBJ *DestObj,
|
||||||
/* Call the driver's DrvStretchBlt if available */
|
/* Call the driver's DrvStretchBlt if available */
|
||||||
if (NULL != DestGDI->StretchBlt)
|
if (NULL != DestGDI->StretchBlt)
|
||||||
{
|
{
|
||||||
/* Drv->StretchBlt params: (look at http://www.osr.com/ddk/graphics/ddifncs_3ew7.htm )
|
/* Drv->StretchBlt (look at http://www.osr.com/ddk/graphics/ddifncs_3ew7.htm )
|
||||||
SURFOBJ *psoDest
|
SURFOBJ *psoMask // optional, if it exists, then rop4=0xCCAA, otherwise rop4=0xCCCC */
|
||||||
SURFOBJ *psoSrc
|
// FIXME: MaskOrigin is always NULL !
|
||||||
SURFOBJ *psoMask // optional, if it exists, then rop4=0xCCAA, otherwise rop4=0xCCCC
|
|
||||||
CLIPOBJ *pco
|
|
||||||
XLATEOBJ *pxlo
|
|
||||||
COLORADJUSTMENT *pca
|
|
||||||
POINTL *pptlHTOrg
|
|
||||||
RECTL *prclDest
|
|
||||||
RECTL *prclSrc
|
|
||||||
POINTL *pptlMask // is it * or not?!
|
|
||||||
ULONG iMode
|
|
||||||
*/
|
|
||||||
//DPRINT1("Calling DrvStretchBlt(%x, %x, %x, %x, %x, ca, %x)...\n", DestObj, SourceObj, Mask, ClipRegion, ColorTranslation, BrushOrigin);
|
|
||||||
ret = DestGDI->StretchBlt(DestObj, SourceObj, Mask, ClipRegion, ColorTranslation,
|
ret = DestGDI->StretchBlt(DestObj, SourceObj, Mask, ClipRegion, ColorTranslation,
|
||||||
&ca, BrushOrigin, &OutputRect, &InputRect, NULL, Mode); // FIXME: MaskOrigin is NULL !
|
&ca, BrushOrigin, &OutputRect, &InputRect, NULL, Mode);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! ret)
|
if (! ret)
|
||||||
{
|
{
|
||||||
ret = FALSE;
|
// FIXME: see previous fixme
|
||||||
//ret = EngBitBlt(DestObj, SourceObj, Mask, ClipRegion, ColorTranslation,
|
ret = EngStretchBlt(DestObj, SourceObj, Mask, ClipRegion, ColorTranslation,
|
||||||
// &OutputRect, &InputPoint, MaskOrigin, Brush, BrushOrigin,
|
&ca, BrushOrigin, &OutputRect, &InputRect, NULL, Mode);
|
||||||
// Rop4);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MouseSafetyOnDrawEnd(DestObj, DestGDI);
|
MouseSafetyOnDrawEnd(DestObj, DestGDI);
|
||||||
|
@ -575,5 +798,4 @@ IntEngStretchBlt(SURFOBJ *DestObj,
|
||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* EOF */
|
/* EOF */
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
*/
|
*/
|
||||||
/* $Id: objects.h,v 1.20 2003/11/10 17:44:49 weiden Exp $
|
/* $Id: objects.h,v 1.21 2003/12/08 18:07:56 fireball Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -154,8 +154,13 @@ typedef VOID (*PFN_DIB_VLine) (SURFOBJ *, LONG, LONG, LONG, ULONG);
|
||||||
typedef BOOLEAN (*PFN_DIB_BitBlt) (SURFOBJ * DestSurf, SURFOBJ * SourceSurf,
|
typedef BOOLEAN (*PFN_DIB_BitBlt) (SURFOBJ * DestSurf, SURFOBJ * SourceSurf,
|
||||||
PSURFGDI DestGDI, PSURFGDI SourceGDI,
|
PSURFGDI DestGDI, PSURFGDI SourceGDI,
|
||||||
RECTL * DestRect, POINTL * SourcePoint,
|
RECTL * DestRect, POINTL * SourcePoint,
|
||||||
BRUSHOBJ *BrushObj, POINTL * BrushOrigin,
|
BRUSHOBJ *BrushObj, POINTL * BrushOrigin,
|
||||||
XLATEOBJ *ColorTranslation, ULONG Rop4);
|
XLATEOBJ *ColorTranslation, ULONG Rop4);
|
||||||
|
typedef BOOLEAN (*PFN_DIB_StretchBlt) (SURFOBJ * DestSurf, SURFOBJ * SourceSurf,
|
||||||
|
PSURFGDI DestGDI, PSURFGDI SourceGDI,
|
||||||
|
RECTL * DestRect, RECTL * SourceRect,
|
||||||
|
POINTL *MaskOrigin, POINTL * BrushOrigin,
|
||||||
|
XLATEOBJ *ColorTranslation, ULONG Mode);
|
||||||
|
|
||||||
typedef struct _SURFGDI {
|
typedef struct _SURFGDI {
|
||||||
ENGOBJ Header;
|
ENGOBJ Header;
|
||||||
|
@ -182,10 +187,11 @@ typedef struct _SURFGDI {
|
||||||
PFN_SetPointerShape SetPointerShape;
|
PFN_SetPointerShape SetPointerShape;
|
||||||
|
|
||||||
/* DIB functions */
|
/* DIB functions */
|
||||||
PFN_DIB_PutPixel DIB_PutPixel;
|
PFN_DIB_PutPixel DIB_PutPixel;
|
||||||
PFN_DIB_HLine DIB_HLine;
|
PFN_DIB_HLine DIB_HLine;
|
||||||
PFN_DIB_VLine DIB_VLine;
|
PFN_DIB_VLine DIB_VLine;
|
||||||
PFN_DIB_BitBlt DIB_BitBlt;
|
PFN_DIB_BitBlt DIB_BitBlt;
|
||||||
|
PFN_DIB_StretchBlt DIB_StretchBlt;
|
||||||
|
|
||||||
/* misc */
|
/* misc */
|
||||||
ULONG PointerStatus;
|
ULONG PointerStatus;
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
* along with this program; if not, write to the Free Software
|
* along with this program; if not, write to the Free Software
|
||||||
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
||||||
*/
|
*/
|
||||||
/* $Id: surface.c,v 1.27 2003/11/18 18:05:40 sedwards Exp $
|
/* $Id: surface.c,v 1.28 2003/12/08 18:07:56 fireball Exp $
|
||||||
*
|
*
|
||||||
* COPYRIGHT: See COPYING in the top level directory
|
* COPYRIGHT: See COPYING in the top level directory
|
||||||
* PROJECT: ReactOS kernel
|
* PROJECT: ReactOS kernel
|
||||||
|
@ -106,22 +106,34 @@ static VOID Dummy_VLine(SURFOBJ* SurfObj, LONG x, LONG y1, LONG y2, ULONG c)
|
||||||
static BOOLEAN Dummy_BitBlt(SURFOBJ *DestSurf, SURFOBJ *SourceSurf,
|
static BOOLEAN Dummy_BitBlt(SURFOBJ *DestSurf, SURFOBJ *SourceSurf,
|
||||||
SURFGDI *DestGDI, SURFGDI *SourceGDI,
|
SURFGDI *DestGDI, SURFGDI *SourceGDI,
|
||||||
RECTL* DestRect, POINTL *SourcePoint,
|
RECTL* DestRect, POINTL *SourcePoint,
|
||||||
BRUSHOBJ* BrushObj, POINTL* BrushOrign,
|
BRUSHOBJ* BrushObj, POINTL* BrushOrign,
|
||||||
XLATEOBJ *ColorTranslation, ULONG Rop4)
|
XLATEOBJ *ColorTranslation, ULONG Rop4)
|
||||||
{
|
{
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static BOOLEAN Dummy_StretchBlt(SURFOBJ *DestSurf, SURFOBJ *SourceSurf,
|
||||||
|
SURFGDI *DestGDI, SURFGDI *SourceGDI,
|
||||||
|
RECTL* DestRect, RECTL *SourceRect,
|
||||||
|
POINTL* MaskOrigin, POINTL* BrushOrign,
|
||||||
|
XLATEOBJ *ColorTranslation, ULONG Mode)
|
||||||
|
{
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#define SURF_METHOD(c,n) DIB_##c##_##n
|
#define SURF_METHOD(c,n) DIB_##c##_##n
|
||||||
#define SET_SURFGDI(c)\
|
#define SET_SURFGDI(c)\
|
||||||
SurfGDI->DIB_PutPixel=SURF_METHOD(c,PutPixel);\
|
SurfGDI->DIB_PutPixel=SURF_METHOD(c,PutPixel);\
|
||||||
SurfGDI->DIB_HLine=SURF_METHOD(c,HLine);\
|
SurfGDI->DIB_HLine=SURF_METHOD(c,HLine);\
|
||||||
SurfGDI->DIB_VLine=SURF_METHOD(c,VLine);\
|
SurfGDI->DIB_VLine=SURF_METHOD(c,VLine);\
|
||||||
SurfGDI->DIB_BitBlt=SURF_METHOD(c,BitBlt);
|
SurfGDI->DIB_BitBlt=SURF_METHOD(c,BitBlt);\
|
||||||
|
SurfGDI->DIB_StretchBlt=SURF_METHOD(c,StretchBlt);
|
||||||
|
|
||||||
VOID FASTCALL InitializeFuncs(SURFGDI *SurfGDI, ULONG BitmapFormat)
|
VOID FASTCALL InitializeFuncs(SURFGDI *SurfGDI, ULONG BitmapFormat)
|
||||||
{
|
{
|
||||||
SurfGDI->BitBlt = NULL;
|
SurfGDI->BitBlt = NULL;
|
||||||
|
SurfGDI->StretchBlt = NULL;
|
||||||
SurfGDI->CopyBits = NULL;
|
SurfGDI->CopyBits = NULL;
|
||||||
SurfGDI->CreateDeviceBitmap = NULL;
|
SurfGDI->CreateDeviceBitmap = NULL;
|
||||||
SurfGDI->SetPalette = NULL;
|
SurfGDI->SetPalette = NULL;
|
||||||
|
@ -142,10 +154,11 @@ VOID FASTCALL InitializeFuncs(SURFGDI *SurfGDI, ULONG BitmapFormat)
|
||||||
DPRINT1("InitializeFuncs: unsupported DIB format %d\n",
|
DPRINT1("InitializeFuncs: unsupported DIB format %d\n",
|
||||||
BitmapFormat);
|
BitmapFormat);
|
||||||
|
|
||||||
SurfGDI->DIB_PutPixel = Dummy_PutPixel;
|
SurfGDI->DIB_PutPixel = Dummy_PutPixel;
|
||||||
SurfGDI->DIB_HLine = Dummy_HLine;
|
SurfGDI->DIB_HLine = Dummy_HLine;
|
||||||
SurfGDI->DIB_VLine = Dummy_VLine;
|
SurfGDI->DIB_VLine = Dummy_VLine;
|
||||||
SurfGDI->DIB_BitBlt = Dummy_BitBlt;
|
SurfGDI->DIB_BitBlt = Dummy_BitBlt;
|
||||||
|
SurfGDI->DIB_StretchBlt = Dummy_StretchBlt;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue