356 BOOL UsesSource, UsesMask;
357 POINTL AdjustedBrushOrigin;
359 BOOLEAN bTopToBottom, bLeftToRight;
370 bLeftToRight =
FALSE;
379 bTopToBottom =
FALSE;
393 DPRINT(
"EngBitBlt: prclTrg: (%d,%d)-(%d,%d)\n",
396 DPRINT(
"EngBitBlt: OutputRect: (%d,%d)-(%d,%d)\n",
409 if (InputPoint.
x < 0)
411 OutputRect.
left -= InputPoint.
x;
414 if (InputPoint.
y < 0)
416 OutputRect.
top -= InputPoint.
y;
419 if (
psoSrc->sizlBitmap.cx < InputPoint.
x +
423 psoSrc->sizlBitmap.cx - InputPoint.
x;
425 if (
psoSrc->sizlBitmap.cy < InputPoint.
y +
429 psoSrc->sizlBitmap.cy - InputPoint.
y;
432 InputRect.
left = InputPoint.
x;
434 InputRect.
top = InputPoint.
y;
441 InputPoint.
x = InputPoint.
y = 0;
450 if (OutputRect.
left <
pco->rclBounds.left)
452 InputRect.
left +=
pco->rclBounds.left - OutputRect.
left;
453 InputPoint.
x +=
pco->rclBounds.left - OutputRect.
left;
454 OutputRect.
left =
pco->rclBounds.left;
456 if (
pco->rclBounds.right < OutputRect.
right)
459 OutputRect.
right =
pco->rclBounds.right;
461 if (OutputRect.
top <
pco->rclBounds.top)
463 InputRect.
top +=
pco->rclBounds.top - OutputRect.
top;
464 InputPoint.
y +=
pco->rclBounds.top - OutputRect.
top;
465 OutputRect.
top =
pco->rclBounds.top;
467 if (
pco->rclBounds.bottom < OutputRect.
bottom)
470 OutputRect.
bottom =
pco->rclBounds.bottom;
476 if (OutputRect.
right <= OutputRect.
left ||
491 AdjustedBrushOrigin.
x = 0;
492 AdjustedBrushOrigin.
y = 0;
502 clippingType =
pco->iDComplexity;
524 if (
pbo &&
pbo->iSolidColor == 0xFFFFFFFF)
535 switch (clippingType)
541 lTmp = OutputRect.
left;
543 OutputRect.
right = lTmp;
548 lTmp = OutputRect.
top;
553 Ret = (*BltRectFunc)(OutputObj,
561 &AdjustedBrushOrigin,
566 ClipRect.
left =
pco->rclBounds.left;
567 ClipRect.
right =
pco->rclBounds.right;
568 ClipRect.
top =
pco->rclBounds.top;
575 AdjustedBrushOrigin.x = BrushOrigin->x + CombinedRect.
left - OutputRect.left;
576 AdjustedBrushOrigin.y = BrushOrigin->y + CombinedRect.
top - OutputRect.top;
579 Pt.
x = InputPoint.x + CombinedRect.
left - OutputRect.left;
580 Pt.
y = InputPoint.y + CombinedRect.
top - OutputRect.top;
581 Ret = (*BltRectFunc)(OutputObj,
589 &AdjustedBrushOrigin,
595 if (OutputObj == InputObj)
597 if (OutputRect.top < InputPoint.y)
599 Direction = OutputRect.left < InputPoint.x ?
604 Direction = OutputRect.left < InputPoint.x ?
618 for (
i = 0;
i < RectEnum.
c;
i++)
629 AdjustedBrushOrigin.x = BrushOrigin->x + CombinedRect.
left - OutputRect.left;
630 AdjustedBrushOrigin.y = BrushOrigin->y + CombinedRect.
top - OutputRect.top;
633 Pt.
x = InputPoint.x + CombinedRect.
left - OutputRect.left;
634 Pt.
y = InputPoint.y + CombinedRect.
top - OutputRect.top;
635 Ret = (*BltRectFunc)(OutputObj,
643 &AdjustedBrushOrigin,
#define BRUSHOBJ_psoMask(pbo)
BOOL(APIENTRY * PBLTRECTFUNC)(SURFOBJ *OutputObj, SURFOBJ *InputObj, SURFOBJ *Mask, XLATEOBJ *ColorTranslation, RECTL *OutputRect, POINTL *InputPoint, POINTL *MaskOrigin, BRUSHOBJ *Brush, POINTL *BrushOrigin, ROP4 Rop4)
WDF_EXTERN_C_START typedef _In_ WDFDEVICE _In_ WDFCONTEXT _In_ WDF_DMA_DIRECTION Direction
static BOOLEAN APIENTRY BltMask(SURFOBJ *psoDest, SURFOBJ *psoSource, SURFOBJ *psoMask, XLATEOBJ *ColorTranslation, RECTL *prclDest, POINTL *pptlSource, POINTL *pptlMask, BRUSHOBJ *pbo, POINTL *pptlBrush, ROP4 Rop4)
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_opt_ POINTL _In_opt_ POINTL _In_opt_ BRUSHOBJ _In_opt_ POINTL _In_ ROP4 rop4
#define ROP4_USES_MASK(Rop4)
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL * prclTrg
static BOOLEAN APIENTRY CallDibBitBlt(SURFOBJ *OutputObj, SURFOBJ *InputObj, SURFOBJ *Mask, XLATEOBJ *ColorTranslation, RECTL *OutputRect, POINTL *InputPoint, POINTL *MaskOrigin, BRUSHOBJ *pbo, POINTL *BrushOrigin, ROP4 Rop4)
#define ROP4_USES_SOURCE(Rop4)
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_opt_ POINTL _In_opt_ POINTL _In_opt_ BRUSHOBJ _In_opt_ POINTL * pptlBrush
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_opt_ POINTL _In_opt_ POINTL _In_opt_ BRUSHOBJ * pbo
ENGAPI ULONG APIENTRY CLIPOBJ_cEnumStart(_Inout_ CLIPOBJ *pco, _In_ BOOL bAll, _In_ ULONG iType, _In_ ULONG iDirection, _In_ ULONG cLimit)
BOOL FASTCALL RECTL_bIntersectRect(_Out_ RECTL *prclDst, _In_ const RECTL *prcl1, _In_ const RECTL *prcl2)
static BOOLEAN APIENTRY BltPatCopy(SURFOBJ *Dest, SURFOBJ *Source, SURFOBJ *Mask, XLATEOBJ *ColorTranslation, RECTL *DestRect, POINTL *SourcePoint, POINTL *MaskPoint, BRUSHOBJ *pbo, POINTL *BrushPoint, DWORD Rop4)
_In_ SURFOBJ _In_ CLIPOBJ * pco
RECTL arcl[ENUM_RECT_LIMIT]
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_opt_ POINTL _In_opt_ POINTL * pptlMask
_In_opt_ SURFOBJ _In_opt_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_opt_ POINTL * pptlSrc
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
_In_opt_ SURFOBJ _In_opt_ SURFOBJ * psoMask
VOID FASTCALL RECTL_vMakeWellOrdered(_Inout_ RECTL *prcl)
ENGAPI BOOL APIENTRY CLIPOBJ_bEnum(_In_ CLIPOBJ *pco, _In_ ULONG cj, _Out_bytecap_(cj) ULONG *pul)
_In_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ * pxlo