101 POINTL AdjustedBrushOrigin;
110 RECTL InputToCombinedRect;
132 clippingType = ClipRegion->iDComplexity;
156 &Translate, &psoInput))
161 InputRect.
left += Translate.
x;
162 InputRect.
right += Translate.
x;
163 InputRect.
top += Translate.
y;
164 InputRect.
bottom += Translate.
y;
175 if (
NULL != ClipRegion)
177 if (OutputRect.
left < ClipRegion->rclBounds.left)
179 InputRect.
left += ClipRegion->rclBounds.left - OutputRect.
left;
180 OutputRect.
left = ClipRegion->rclBounds.left;
182 if (ClipRegion->rclBounds.right < OutputRect.
right)
184 InputRect.
right -= OutputRect.
right - ClipRegion->rclBounds.right;
185 OutputRect.
right = ClipRegion->rclBounds.right;
187 if (OutputRect.
top < ClipRegion->rclBounds.top)
189 InputRect.
top += ClipRegion->rclBounds.top - OutputRect.
top;
190 OutputRect.
top = ClipRegion->rclBounds.top;
192 if (ClipRegion->rclBounds.bottom < OutputRect.
bottom)
194 InputRect.
bottom -= OutputRect.
bottom - ClipRegion->rclBounds.bottom;
195 OutputRect.
bottom = ClipRegion->rclBounds.bottom;
210 if (!
IntEngEnter(&EnterLeaveDest, psoDest, &OutputRect,
FALSE, &Translate, &psoOutput))
219 OutputRect.
left += Translate.
x;
220 OutputRect.
right += Translate.
x;
221 OutputRect.
top += Translate.
y;
222 OutputRect.
bottom += Translate.
y;
226 AdjustedBrushOrigin.
x = BrushOrigin->x + Translate.
x;
227 AdjustedBrushOrigin.
y = BrushOrigin->y + Translate.
y;
231 AdjustedBrushOrigin = Translate;
236 DstHeight = OutputRect.
bottom - OutputRect.
top;
237 DstWidth = OutputRect.
right - OutputRect.
left;
238 SrcHeight = InputRect.
bottom - InputRect.
top;
239 SrcWidth = InputRect.
right - InputRect.
left;
240 switch (clippingType)
243 Ret = (*BltRectFunc)(psoOutput, psoInput,
Mask,
244 ColorTranslation, &OutputRect, &InputRect, MaskOrigin,
245 pbo, &AdjustedBrushOrigin, Rop4);
249 ClipRect.
left = ClipRegion->rclBounds.left + Translate.
x;
250 ClipRect.
right = ClipRegion->rclBounds.right + Translate.
x;
251 ClipRect.
top = ClipRegion->rclBounds.top + Translate.
y;
252 ClipRect.
bottom = ClipRegion->rclBounds.bottom + Translate.
y;
255 InputToCombinedRect.
top = InputRect.top + (CombinedRect.
top - OutputRect.top) * SrcHeight / DstHeight;
256 InputToCombinedRect.
bottom = InputRect.top + (CombinedRect.
bottom - OutputRect.top) * SrcHeight / DstHeight;
257 InputToCombinedRect.
left = InputRect.left + (CombinedRect.
left - OutputRect.left) * SrcWidth / DstWidth;
258 InputToCombinedRect.
right = InputRect.left + (CombinedRect.
right - OutputRect.left) * SrcWidth / DstWidth;
259 Ret = (*BltRectFunc)(psoOutput, psoInput,
Mask,
262 &InputToCombinedRect,
265 &AdjustedBrushOrigin,
270 if (psoOutput == psoInput)
272 if (OutputRect.top < InputRect.top)
274 Direction = OutputRect.left < InputRect.left ?
279 Direction = OutputRect.left < InputRect.left ?
292 for (
i = 0;
i < RectEnum.
c;
i++)
300 InputToCombinedRect.
top = InputRect.top + (CombinedRect.
top - OutputRect.top) * SrcHeight / DstHeight;
301 InputToCombinedRect.
bottom = InputRect.top + (CombinedRect.
bottom - OutputRect.top) * SrcHeight / DstHeight;
302 InputToCombinedRect.
left = InputRect.left + (CombinedRect.
left - OutputRect.left) * SrcWidth / DstWidth;
303 InputToCombinedRect.
right = InputRect.left + (CombinedRect.
right - OutputRect.left) * SrcWidth / DstWidth;
304 Ret = (*BltRectFunc)(psoOutput, psoInput,
Mask,
307 &InputToCombinedRect,
310 &AdjustedBrushOrigin,
WDF_EXTERN_C_START typedef _In_ WDFDEVICE _In_ WDFCONTEXT _In_ WDF_DMA_DIRECTION Direction
BOOLEAN(APIENTRY * PSTRETCHRECTFUNC)(SURFOBJ *OutputObj, SURFOBJ *InputObj, SURFOBJ *Mask, XLATEOBJ *ColorTranslation, RECTL *OutputRect, RECTL *InputRect, POINTL *MaskOrigin, BRUSHOBJ *pbo, POINTL *BrushOrigin, ROP4 Rop4)
#define ROP4_USES_SOURCE(Rop4)
_In_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL _In_ RECTL * prclSrc
_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)
_In_ SURFOBJ _In_ CLIPOBJ _In_opt_ XLATEOBJ _In_ RECTL * prclDest
BOOL APIENTRY IntEngEnter(PINTENG_ENTER_LEAVE EnterLeave, SURFOBJ *psoDest, RECTL *DestRect, BOOL ReadOnly, POINTL *Translate, SURFOBJ **ppsoOutput)
RECTL arcl[ENUM_RECT_LIMIT]
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
BOOL APIENTRY IntEngLeave(PINTENG_ENTER_LEAVE EnterLeave)
static BOOLEAN APIENTRY CallDibStretchBlt(SURFOBJ *psoDest, SURFOBJ *psoSource, SURFOBJ *Mask, XLATEOBJ *ColorTranslation, RECTL *OutputRect, RECTL *InputRect, POINTL *MaskOrigin, BRUSHOBJ *pbo, POINTL *BrushOrigin, ROP4 Rop4)
ENGAPI BOOL APIENTRY CLIPOBJ_bEnum(_In_ CLIPOBJ *pco, _In_ ULONG cj, _Out_bytecap_(cj) ULONG *pul)