Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
3d34f01f
Commit
3d34f01f
authored
Mar 18, 2011
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gdi32: Add null driver entry points for StretchBlt and AlphaBlend.
parent
5ffbce6d
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
106 additions
and
97 deletions
+106
-97
bitblt.c
dlls/gdi32/bitblt.c
+70
-71
driver.c
dlls/gdi32/driver.c
+9
-2
bitblt.c
dlls/gdi32/enhmfdrv/bitblt.c
+6
-5
gdi_private.h
dlls/gdi32/gdi_private.h
+2
-0
bitblt.c
dlls/gdi32/mfdrv/bitblt.c
+8
-7
bitblt.c
dlls/winex11.drv/bitblt.c
+5
-3
x11drv.h
dlls/winex11.drv/x11drv.h
+6
-9
No files found.
dlls/gdi32/bitblt.c
View file @
3d34f01f
...
@@ -40,6 +40,62 @@ static inline BOOL rop_uses_src( DWORD rop )
...
@@ -40,6 +40,62 @@ static inline BOOL rop_uses_src( DWORD rop )
return
((
rop
>>
2
)
&
0x330000
)
!=
(
rop
&
0x330000
);
return
((
rop
>>
2
)
&
0x330000
)
!=
(
rop
&
0x330000
);
}
}
/* nulldrv fallback implementation using StretchDIBits */
BOOL
CDECL
nulldrv_StretchBlt
(
PHYSDEV
dst_dev
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
PHYSDEV
src_dev
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
DWORD
rop
)
{
DC
*
dc
=
get_nulldrv_dc
(
dst_dev
);
BITMAP
bm
;
BITMAPINFOHEADER
info_hdr
;
HBITMAP
hbm
;
LPVOID
bits
;
INT
lines
;
POINT
pts
[
2
];
/* make sure we have a real implementation for StretchDIBits */
if
(
GET_DC_PHYSDEV
(
dc
,
pStretchDIBits
)
==
dst_dev
)
return
0
;
pts
[
0
].
x
=
xSrc
;
pts
[
0
].
y
=
ySrc
;
pts
[
1
].
x
=
xSrc
+
widthSrc
;
pts
[
1
].
y
=
ySrc
+
heightSrc
;
LPtoDP
(
src_dev
->
hdc
,
pts
,
2
);
xSrc
=
pts
[
0
].
x
;
ySrc
=
pts
[
0
].
y
;
widthSrc
=
pts
[
1
].
x
-
pts
[
0
].
x
;
heightSrc
=
pts
[
1
].
y
-
pts
[
0
].
y
;
if
(
GetObjectType
(
src_dev
->
hdc
)
!=
OBJ_MEMDC
)
return
FALSE
;
if
(
!
GetObjectW
(
GetCurrentObject
(
src_dev
->
hdc
,
OBJ_BITMAP
),
sizeof
(
bm
),
&
bm
))
return
FALSE
;
info_hdr
.
biSize
=
sizeof
(
info_hdr
);
info_hdr
.
biWidth
=
bm
.
bmWidth
;
info_hdr
.
biHeight
=
bm
.
bmHeight
;
info_hdr
.
biPlanes
=
1
;
info_hdr
.
biBitCount
=
32
;
info_hdr
.
biCompression
=
BI_RGB
;
info_hdr
.
biSizeImage
=
0
;
info_hdr
.
biXPelsPerMeter
=
0
;
info_hdr
.
biYPelsPerMeter
=
0
;
info_hdr
.
biClrUsed
=
0
;
info_hdr
.
biClrImportant
=
0
;
if
(
!
(
bits
=
HeapAlloc
(
GetProcessHeap
(),
0
,
bm
.
bmHeight
*
bm
.
bmWidth
*
4
)))
return
FALSE
;
/* Select out the src bitmap before calling GetDIBits */
hbm
=
SelectObject
(
src_dev
->
hdc
,
GetStockObject
(
DEFAULT_BITMAP
)
);
lines
=
GetDIBits
(
src_dev
->
hdc
,
hbm
,
0
,
bm
.
bmHeight
,
bits
,
(
BITMAPINFO
*
)
&
info_hdr
,
DIB_RGB_COLORS
);
SelectObject
(
src_dev
->
hdc
,
hbm
);
if
(
lines
)
lines
=
StretchDIBits
(
dst_dev
->
hdc
,
xDst
,
yDst
,
widthDst
,
heightDst
,
xSrc
,
bm
.
bmHeight
-
heightSrc
-
ySrc
,
widthSrc
,
heightSrc
,
bits
,
(
BITMAPINFO
*
)
&
info_hdr
,
DIB_RGB_COLORS
,
rop
);
HeapFree
(
GetProcessHeap
(),
0
,
bits
);
return
(
lines
==
heightSrc
);
}
/***********************************************************************
/***********************************************************************
* PatBlt (GDI32.@)
* PatBlt (GDI32.@)
*/
*/
...
@@ -89,76 +145,19 @@ BOOL WINAPI StretchBlt( HDC hdcDst, INT xDst, INT yDst, INT widthDst, INT height
...
@@ -89,76 +145,19 @@ BOOL WINAPI StretchBlt( HDC hdcDst, INT xDst, INT yDst, INT widthDst, INT height
hdcSrc
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
hdcSrc
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
hdcDst
,
xDst
,
yDst
,
widthDst
,
heightDst
,
rop
);
hdcDst
,
xDst
,
yDst
,
widthDst
,
heightDst
,
rop
);
if
(
!
(
dcDst
=
get_dc_ptr
(
hdcDst
)))
return
FALSE
;
if
(
!
(
dcDst
=
get_dc_ptr
(
hdcDst
)))
return
FALSE
;
update_dc
(
dcDst
);
if
(
dcDst
->
funcs
->
pStretchBlt
)
{
if
((
dcSrc
=
get_dc_ptr
(
hdcSrc
)))
if
((
dcSrc
=
get_dc_ptr
(
hdcSrc
)))
{
{
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pStretchBlt
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pStretchBlt
);
update_dc
(
dcSrc
);
update_dc
(
dcSrc
);
update_dc
(
dcDst
);
ret
=
dcDst
->
funcs
->
pStretchBlt
(
dcDst
->
physDev
,
xDst
,
yDst
,
widthDst
,
heightDst
,
ret
=
dst_dev
->
funcs
->
pStretchBlt
(
dst_dev
,
xDst
,
yDst
,
widthDst
,
heightDst
,
dcSrc
->
physDev
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
src_dev
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
rop
);
rop
);
release_dc_ptr
(
dcSrc
);
release_dc_ptr
(
dcSrc
);
}
}
release_dc_ptr
(
dcDst
);
release_dc_ptr
(
dcDst
);
}
else
if
(
dcDst
->
funcs
->
pStretchDIBits
)
{
BITMAP
bm
;
BITMAPINFOHEADER
info_hdr
;
HBITMAP
hbm
;
LPVOID
bits
;
INT
lines
;
POINT
pts
[
2
];
pts
[
0
].
x
=
xSrc
;
pts
[
0
].
y
=
ySrc
;
pts
[
1
].
x
=
xSrc
+
widthSrc
;
pts
[
1
].
y
=
ySrc
+
heightSrc
;
LPtoDP
(
hdcSrc
,
pts
,
2
);
xSrc
=
pts
[
0
].
x
;
ySrc
=
pts
[
0
].
y
;
widthSrc
=
pts
[
1
].
x
-
pts
[
0
].
x
;
heightSrc
=
pts
[
1
].
y
-
pts
[
0
].
y
;
release_dc_ptr
(
dcDst
);
if
(
GetObjectType
(
hdcSrc
)
!=
OBJ_MEMDC
)
return
FALSE
;
GetObjectW
(
GetCurrentObject
(
hdcSrc
,
OBJ_BITMAP
),
sizeof
(
bm
),
&
bm
);
info_hdr
.
biSize
=
sizeof
(
info_hdr
);
info_hdr
.
biWidth
=
bm
.
bmWidth
;
info_hdr
.
biHeight
=
bm
.
bmHeight
;
info_hdr
.
biPlanes
=
1
;
info_hdr
.
biBitCount
=
32
;
info_hdr
.
biCompression
=
BI_RGB
;
info_hdr
.
biSizeImage
=
0
;
info_hdr
.
biXPelsPerMeter
=
0
;
info_hdr
.
biYPelsPerMeter
=
0
;
info_hdr
.
biClrUsed
=
0
;
info_hdr
.
biClrImportant
=
0
;
if
(
!
(
bits
=
HeapAlloc
(
GetProcessHeap
(),
0
,
bm
.
bmHeight
*
bm
.
bmWidth
*
4
)))
return
FALSE
;
/* Select out the src bitmap before calling GetDIBits */
hbm
=
SelectObject
(
hdcSrc
,
GetStockObject
(
DEFAULT_BITMAP
));
GetDIBits
(
hdcSrc
,
hbm
,
0
,
bm
.
bmHeight
,
bits
,
(
BITMAPINFO
*
)
&
info_hdr
,
DIB_RGB_COLORS
);
SelectObject
(
hdcSrc
,
hbm
);
lines
=
StretchDIBits
(
hdcDst
,
xDst
,
yDst
,
widthDst
,
heightDst
,
xSrc
,
bm
.
bmHeight
-
heightSrc
-
ySrc
,
widthSrc
,
heightSrc
,
bits
,
(
BITMAPINFO
*
)
&
info_hdr
,
DIB_RGB_COLORS
,
rop
);
HeapFree
(
GetProcessHeap
(),
0
,
bits
);
return
(
lines
==
heightSrc
);
}
else
release_dc_ptr
(
dcDst
);
return
ret
;
return
ret
;
}
}
...
@@ -456,22 +455,22 @@ BOOL WINAPI GdiAlphaBlend(HDC hdcDst, int xDst, int yDst, int widthDst, int heig
...
@@ -456,22 +455,22 @@ BOOL WINAPI GdiAlphaBlend(HDC hdcDst, int xDst, int yDst, int widthDst, int heig
BOOL
ret
=
FALSE
;
BOOL
ret
=
FALSE
;
DC
*
dcDst
,
*
dcSrc
;
DC
*
dcDst
,
*
dcSrc
;
TRACE
(
"%p %d,%d %dx%d -> %p %d,%d %dx%d op=%02x flags=%02x srcconstalpha=%02x alphafmt=%02x
\n
"
,
hdcSrc
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
hdcDst
,
xDst
,
yDst
,
widthDst
,
heightDst
,
blendFunction
.
BlendOp
,
blendFunction
.
BlendFlags
,
blendFunction
.
SourceConstantAlpha
,
blendFunction
.
AlphaFormat
);
dcSrc
=
get_dc_ptr
(
hdcSrc
);
dcSrc
=
get_dc_ptr
(
hdcSrc
);
if
(
!
dcSrc
)
return
FALSE
;
if
(
!
dcSrc
)
return
FALSE
;
if
((
dcDst
=
get_dc_ptr
(
hdcDst
)))
if
((
dcDst
=
get_dc_ptr
(
hdcDst
)))
{
{
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pAlphaBlend
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pAlphaBlend
);
update_dc
(
dcSrc
);
update_dc
(
dcSrc
);
update_dc
(
dcDst
);
update_dc
(
dcDst
);
TRACE
(
"%p %d,%d %dx%d -> %p %d,%d %dx%d op=%02x flags=%02x srcconstalpha=%02x alphafmt=%02x
\n
"
,
ret
=
dst_dev
->
funcs
->
pAlphaBlend
(
dst_dev
,
xDst
,
yDst
,
widthDst
,
heightDst
,
hdcSrc
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
src_dev
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
blendFunction
);
hdcDst
,
xDst
,
yDst
,
widthDst
,
heightDst
,
blendFunction
.
BlendOp
,
blendFunction
.
BlendFlags
,
blendFunction
.
SourceConstantAlpha
,
blendFunction
.
AlphaFormat
);
if
(
dcDst
->
funcs
->
pAlphaBlend
)
ret
=
dcDst
->
funcs
->
pAlphaBlend
(
dcDst
->
physDev
,
xDst
,
yDst
,
widthDst
,
heightDst
,
dcSrc
->
physDev
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
blendFunction
);
release_dc_ptr
(
dcDst
);
release_dc_ptr
(
dcDst
);
}
}
release_dc_ptr
(
dcSrc
);
release_dc_ptr
(
dcSrc
);
...
...
dlls/gdi32/driver.c
View file @
3d34f01f
...
@@ -317,6 +317,13 @@ static INT CDECL nulldrv_AbortDoc( PHYSDEV dev )
...
@@ -317,6 +317,13 @@ static INT CDECL nulldrv_AbortDoc( PHYSDEV dev )
return
0
;
return
0
;
}
}
static
BOOL
CDECL
nulldrv_AlphaBlend
(
PHYSDEV
dst_dev
,
INT
x_dst
,
INT
y_dst
,
INT
width_dst
,
INT
height_dst
,
PHYSDEV
src_dev
,
INT
x_src
,
INT
y_src
,
INT
width_src
,
INT
height_src
,
BLENDFUNCTION
func
)
{
return
TRUE
;
}
static
BOOL
CDECL
nulldrv_Arc
(
PHYSDEV
dev
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
,
static
BOOL
CDECL
nulldrv_Arc
(
PHYSDEV
dev
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
,
INT
xstart
,
INT
ystart
,
INT
xend
,
INT
yend
)
INT
xstart
,
INT
ystart
,
INT
xend
,
INT
yend
)
{
{
...
@@ -788,7 +795,7 @@ const DC_FUNCTIONS null_driver =
...
@@ -788,7 +795,7 @@ const DC_FUNCTIONS null_driver =
{
{
nulldrv_AbortDoc
,
/* pAbortDoc */
nulldrv_AbortDoc
,
/* pAbortDoc */
nulldrv_AbortPath
,
/* pAbortPath */
nulldrv_AbortPath
,
/* pAbortPath */
NULL
,
/* pAlphaBlend */
nulldrv_AlphaBlend
,
/* pAlphaBlend */
nulldrv_AngleArc
,
/* pAngleArc */
nulldrv_AngleArc
,
/* pAngleArc */
nulldrv_Arc
,
/* pArc */
nulldrv_Arc
,
/* pArc */
nulldrv_ArcTo
,
/* pArcTo */
nulldrv_ArcTo
,
/* pArcTo */
...
@@ -898,7 +905,7 @@ const DC_FUNCTIONS null_driver =
...
@@ -898,7 +905,7 @@ const DC_FUNCTIONS null_driver =
nulldrv_SetWorldTransform
,
/* pSetWorldTransform */
nulldrv_SetWorldTransform
,
/* pSetWorldTransform */
nulldrv_StartDoc
,
/* pStartDoc */
nulldrv_StartDoc
,
/* pStartDoc */
nulldrv_StartPage
,
/* pStartPage */
nulldrv_StartPage
,
/* pStartPage */
NULL
,
/* pStretchBlt */
nulldrv_StretchBlt
,
/* pStretchBlt */
nulldrv_StretchDIBits
,
/* pStretchDIBits */
nulldrv_StretchDIBits
,
/* pStretchDIBits */
nulldrv_StrokeAndFillPath
,
/* pStrokeAndFillPath */
nulldrv_StrokeAndFillPath
,
/* pStrokeAndFillPath */
nulldrv_StrokePath
,
/* pStrokePath */
nulldrv_StrokePath
,
/* pStrokePath */
...
...
dlls/gdi32/enhmfdrv/bitblt.c
View file @
3d34f01f
...
@@ -77,10 +77,11 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -77,10 +77,11 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
BITMAP
BM
;
BITMAP
BM
;
WORD
nBPP
=
0
;
WORD
nBPP
=
0
;
LPBITMAPINFOHEADER
lpBmiH
;
LPBITMAPINFOHEADER
lpBmiH
;
EMFDRV_PDEVICE
*
physDevSrc
=
(
EMFDRV_PDEVICE
*
)
devSrc
;
HBITMAP
hBitmap
=
NULL
;
HBITMAP
hBitmap
=
NULL
;
DWORD
emrType
;
DWORD
emrType
;
if
(
devSrc
->
funcs
==
devDst
->
funcs
)
return
FALSE
;
/* can't use a metafile DC as source */
if
(
widthSrc
==
widthDst
&&
heightSrc
==
heightDst
)
if
(
widthSrc
==
widthDst
&&
heightSrc
==
heightDst
)
{
{
emrType
=
EMR_BITBLT
;
emrType
=
EMR_BITBLT
;
...
@@ -92,7 +93,7 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -92,7 +93,7 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
emrSize
=
sizeof
(
EMRSTRETCHBLT
);
emrSize
=
sizeof
(
EMRSTRETCHBLT
);
}
}
hBitmap
=
GetCurrentObject
(
physD
evSrc
->
hdc
,
OBJ_BITMAP
);
hBitmap
=
GetCurrentObject
(
d
evSrc
->
hdc
,
OBJ_BITMAP
);
if
(
sizeof
(
BITMAP
)
!=
GetObjectW
(
hBitmap
,
sizeof
(
BITMAP
),
&
BM
))
if
(
sizeof
(
BITMAP
)
!=
GetObjectW
(
hBitmap
,
sizeof
(
BITMAP
),
&
BM
))
return
FALSE
;
return
FALSE
;
...
@@ -122,8 +123,8 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -122,8 +123,8 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
pEMR
->
dwRop
=
rop
;
pEMR
->
dwRop
=
rop
;
pEMR
->
xSrc
=
xSrc
;
pEMR
->
xSrc
=
xSrc
;
pEMR
->
ySrc
=
ySrc
;
pEMR
->
ySrc
=
ySrc
;
GetWorldTransform
(
physD
evSrc
->
hdc
,
&
pEMR
->
xformSrc
);
GetWorldTransform
(
d
evSrc
->
hdc
,
&
pEMR
->
xformSrc
);
pEMR
->
crBkColorSrc
=
GetBkColor
(
physD
evSrc
->
hdc
);
pEMR
->
crBkColorSrc
=
GetBkColor
(
d
evSrc
->
hdc
);
pEMR
->
iUsageSrc
=
DIB_RGB_COLORS
;
pEMR
->
iUsageSrc
=
DIB_RGB_COLORS
;
pEMR
->
offBmiSrc
=
emrSize
;
pEMR
->
offBmiSrc
=
emrSize
;
pEMR
->
offBitsSrc
=
emrSize
+
bmiSize
;
pEMR
->
offBitsSrc
=
emrSize
+
bmiSize
;
...
@@ -155,7 +156,7 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -155,7 +156,7 @@ BOOL CDECL EMFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
lpBmiH
->
biClrImportant
=
0
;
lpBmiH
->
biClrImportant
=
0
;
/* Initialize bitmap bits */
/* Initialize bitmap bits */
if
(
GetDIBits
(
physD
evSrc
->
hdc
,
hBitmap
,
0
,
(
UINT
)
lpBmiH
->
biHeight
,
if
(
GetDIBits
(
d
evSrc
->
hdc
,
hBitmap
,
0
,
(
UINT
)
lpBmiH
->
biHeight
,
(
BYTE
*
)
pEMR
+
pEMR
->
offBitsSrc
,
(
BYTE
*
)
pEMR
+
pEMR
->
offBitsSrc
,
(
LPBITMAPINFO
)
lpBmiH
,
DIB_RGB_COLORS
))
(
LPBITMAPINFO
)
lpBmiH
,
DIB_RGB_COLORS
))
{
{
...
...
dlls/gdi32/gdi_private.h
View file @
3d34f01f
...
@@ -548,6 +548,8 @@ extern BOOL CDECL nulldrv_SetViewportOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt
...
@@ -548,6 +548,8 @@ extern BOOL CDECL nulldrv_SetViewportOrgEx( PHYSDEV dev, INT x, INT y, POINT *pt
extern
BOOL
CDECL
nulldrv_SetWindowExtEx
(
PHYSDEV
dev
,
INT
cx
,
INT
cy
,
SIZE
*
size
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_SetWindowExtEx
(
PHYSDEV
dev
,
INT
cx
,
INT
cy
,
SIZE
*
size
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_SetWindowOrgEx
(
PHYSDEV
dev
,
INT
x
,
INT
y
,
POINT
*
pt
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_SetWindowOrgEx
(
PHYSDEV
dev
,
INT
x
,
INT
y
,
POINT
*
pt
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_SetWorldTransform
(
PHYSDEV
dev
,
const
XFORM
*
xform
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_SetWorldTransform
(
PHYSDEV
dev
,
const
XFORM
*
xform
)
DECLSPEC_HIDDEN
;
extern
BOOL
CDECL
nulldrv_StretchBlt
(
PHYSDEV
dst_dev
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
PHYSDEV
src_dev
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
DWORD
rop
)
DECLSPEC_HIDDEN
;
extern
INT
CDECL
nulldrv_StretchDIBits
(
PHYSDEV
dev
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
extern
INT
CDECL
nulldrv_StretchDIBits
(
PHYSDEV
dev
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
const
void
*
bits
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
const
void
*
bits
,
const
BITMAPINFO
*
info
,
UINT
coloruse
,
DWORD
rop
)
DECLSPEC_HIDDEN
;
const
BITMAPINFO
*
info
,
UINT
coloruse
,
DWORD
rop
)
DECLSPEC_HIDDEN
;
...
...
dlls/gdi32/mfdrv/bitblt.c
View file @
3d34f01f
...
@@ -51,16 +51,17 @@ BOOL CDECL MFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -51,16 +51,17 @@ BOOL CDECL MFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
DWORD
len
;
DWORD
len
;
METARECORD
*
mr
;
METARECORD
*
mr
;
BITMAP
BM
;
BITMAP
BM
;
METAFILEDRV_PDEVICE
*
physDevSrc
=
(
METAFILEDRV_PDEVICE
*
)
devSrc
;
#ifdef STRETCH_VIA_DIB
#ifdef STRETCH_VIA_DIB
LPBITMAPINFOHEADER
lpBMI
;
LPBITMAPINFOHEADER
lpBMI
;
WORD
nBPP
;
WORD
nBPP
;
#endif
#endif
HBITMAP
hBitmap
=
GetCurrentObject
(
physDevSrc
->
hdc
,
OBJ_BITMAP
);
HBITMAP
hBitmap
=
GetCurrentObject
(
devSrc
->
hdc
,
OBJ_BITMAP
);
if
(
devSrc
->
funcs
==
devDst
->
funcs
)
return
FALSE
;
/* can't use a metafile DC as source */
if
(
GetObjectW
(
hBitmap
,
sizeof
(
BITMAP
),
&
BM
)
!=
sizeof
(
BITMAP
))
if
(
GetObjectW
(
hBitmap
,
sizeof
(
BITMAP
),
&
BM
)
!=
sizeof
(
BITMAP
))
{
{
WARN
(
"bad bitmap object %p passed for hdc %p
\n
"
,
hBitmap
,
physD
evSrc
->
hdc
);
WARN
(
"bad bitmap object %p passed for hdc %p
\n
"
,
hBitmap
,
d
evSrc
->
hdc
);
return
FALSE
;
return
FALSE
;
}
}
#ifdef STRETCH_VIA_DIB
#ifdef STRETCH_VIA_DIB
...
@@ -81,14 +82,14 @@ BOOL CDECL MFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
...
@@ -81,14 +82,14 @@ BOOL CDECL MFDRV_StretchBlt( PHYSDEV devDst, INT xDst, INT yDst, INT widthDst,
lpBMI
->
biSizeImage
=
DIB_GetDIBWidthBytes
(
BM
.
bmWidth
,
nBPP
)
*
lpBMI
->
biHeight
;
lpBMI
->
biSizeImage
=
DIB_GetDIBWidthBytes
(
BM
.
bmWidth
,
nBPP
)
*
lpBMI
->
biHeight
;
lpBMI
->
biClrUsed
=
nBPP
<=
8
?
1
<<
nBPP
:
0
;
lpBMI
->
biClrUsed
=
nBPP
<=
8
?
1
<<
nBPP
:
0
;
lpBMI
->
biCompression
=
BI_RGB
;
lpBMI
->
biCompression
=
BI_RGB
;
lpBMI
->
biXPelsPerMeter
=
MulDiv
(
GetDeviceCaps
(
physD
evSrc
->
hdc
,
LOGPIXELSX
),
3937
,
100
);
lpBMI
->
biXPelsPerMeter
=
MulDiv
(
GetDeviceCaps
(
d
evSrc
->
hdc
,
LOGPIXELSX
),
3937
,
100
);
lpBMI
->
biYPelsPerMeter
=
MulDiv
(
GetDeviceCaps
(
physD
evSrc
->
hdc
,
LOGPIXELSY
),
3937
,
100
);
lpBMI
->
biYPelsPerMeter
=
MulDiv
(
GetDeviceCaps
(
d
evSrc
->
hdc
,
LOGPIXELSY
),
3937
,
100
);
lpBMI
->
biClrImportant
=
0
;
/* 1 meter = 39.37 inch */
lpBMI
->
biClrImportant
=
0
;
/* 1 meter = 39.37 inch */
TRACE
(
"MF_StretchBltViaDIB->len = %d rop=%x PixYPM=%d Caps=%d
\n
"
,
TRACE
(
"MF_StretchBltViaDIB->len = %d rop=%x PixYPM=%d Caps=%d
\n
"
,
len
,
rop
,
lpBMI
->
biYPelsPerMeter
,
GetDeviceCaps
(
physD
evSrc
->
hdc
,
LOGPIXELSY
));
len
,
rop
,
lpBMI
->
biYPelsPerMeter
,
GetDeviceCaps
(
d
evSrc
->
hdc
,
LOGPIXELSY
));
if
(
GetDIBits
(
physD
evSrc
->
hdc
,
hBitmap
,
0
,
(
UINT
)
lpBMI
->
biHeight
,
if
(
GetDIBits
(
d
evSrc
->
hdc
,
hBitmap
,
0
,
(
UINT
)
lpBMI
->
biHeight
,
(
LPSTR
)
lpBMI
+
bitmap_info_size
(
(
BITMAPINFO
*
)
lpBMI
,
(
LPSTR
)
lpBMI
+
bitmap_info_size
(
(
BITMAPINFO
*
)
lpBMI
,
DIB_RGB_COLORS
),
DIB_RGB_COLORS
),
(
LPBITMAPINFO
)
lpBMI
,
DIB_RGB_COLORS
))
(
LPBITMAPINFO
)
lpBMI
,
DIB_RGB_COLORS
))
...
...
dlls/winex11.drv/bitblt.c
View file @
3d34f01f
...
@@ -1486,9 +1486,10 @@ BOOL CDECL X11DRV_PatBlt( X11DRV_PDEVICE *physDev, INT x, INT y, INT width, INT
...
@@ -1486,9 +1486,10 @@ BOOL CDECL X11DRV_PatBlt( X11DRV_PDEVICE *physDev, INT x, INT y, INT width, INT
* X11DRV_StretchBlt
* X11DRV_StretchBlt
*/
*/
BOOL
CDECL
X11DRV_StretchBlt
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
BOOL
CDECL
X11DRV_StretchBlt
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
X11DRV_PDEVICE
*
physDevSrc
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
PHYSDEV
src_dev
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
DWORD
rop
)
DWORD
rop
)
{
{
X11DRV_PDEVICE
*
physDevSrc
=
(
X11DRV_PDEVICE
*
)
src_dev
;
/* FIXME: check that it's really an x11 dev */
BOOL
usePat
,
useDst
,
destUsed
,
fStretch
,
fNullBrush
;
BOOL
usePat
,
useDst
,
destUsed
,
fStretch
,
fNullBrush
;
struct
bitblt_coords
src
,
dst
;
struct
bitblt_coords
src
,
dst
;
INT
width
,
height
;
INT
width
,
height
;
...
@@ -1504,7 +1505,7 @@ BOOL CDECL X11DRV_StretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT yDst, IN
...
@@ -1504,7 +1505,7 @@ BOOL CDECL X11DRV_StretchBlt( X11DRV_PDEVICE *physDevDst, INT xDst, INT yDst, IN
src
.
y
=
ySrc
;
src
.
y
=
ySrc
;
src
.
width
=
widthSrc
;
src
.
width
=
widthSrc
;
src
.
height
=
heightSrc
;
src
.
height
=
heightSrc
;
src
.
layout
=
physDevSrc
?
GetLayout
(
physDevSrc
->
hdc
)
:
0
;
src
.
layout
=
GetLayout
(
physDevSrc
->
hdc
)
;
dst
.
x
=
xDst
;
dst
.
x
=
xDst
;
dst
.
y
=
yDst
;
dst
.
y
=
yDst
;
dst
.
width
=
widthDst
;
dst
.
width
=
widthDst
;
...
@@ -1685,9 +1686,10 @@ done:
...
@@ -1685,9 +1686,10 @@ done:
* X11DRV_AlphaBlend
* X11DRV_AlphaBlend
*/
*/
BOOL
CDECL
X11DRV_AlphaBlend
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
BOOL
CDECL
X11DRV_AlphaBlend
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
X11DRV_PDEVICE
*
physDevSrc
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
PHYSDEV
src_dev
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
BLENDFUNCTION
blendfn
)
BLENDFUNCTION
blendfn
)
{
{
X11DRV_PDEVICE
*
physDevSrc
=
(
X11DRV_PDEVICE
*
)
src_dev
;
/* FIXME: check that it's really an x11 dev */
struct
bitblt_coords
src
,
dst
;
struct
bitblt_coords
src
,
dst
;
src
.
x
=
xSrc
;
src
.
x
=
xSrc
;
...
...
dlls/winex11.drv/x11drv.h
View file @
3d34f01f
...
@@ -141,10 +141,15 @@ typedef UINT X_PHYSFONT;
...
@@ -141,10 +141,15 @@ typedef UINT X_PHYSFONT;
struct
xrender_info
;
struct
xrender_info
;
typedef
struct
gdi_physdev
{
void
*
reserved
[
3
];
}
*
PHYSDEV
;
/* X physical device */
/* X physical device */
typedef
struct
typedef
struct
{
{
void
*
reserved
[
3
];
/* reserved for gdi */
struct
gdi_physdev
dev
;
HDC
hdc
;
HDC
hdc
;
GC
gc
;
/* X Window GC */
GC
gc
;
/* X Window GC */
Drawable
drawable
;
Drawable
drawable
;
...
@@ -186,10 +191,6 @@ extern GC get_bitmap_gc(int depth);
...
@@ -186,10 +191,6 @@ extern GC get_bitmap_gc(int depth);
/* Wine driver X11 functions */
/* Wine driver X11 functions */
extern
BOOL
CDECL
X11DRV_AlphaBlend
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
X11DRV_PDEVICE
*
physDevSrc
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
BLENDFUNCTION
blendfn
);
extern
BOOL
CDECL
X11DRV_EnumDeviceFonts
(
X11DRV_PDEVICE
*
physDev
,
LPLOGFONTW
plf
,
extern
BOOL
CDECL
X11DRV_EnumDeviceFonts
(
X11DRV_PDEVICE
*
physDev
,
LPLOGFONTW
plf
,
FONTENUMPROCW
dfeproc
,
LPARAM
lp
);
FONTENUMPROCW
dfeproc
,
LPARAM
lp
);
extern
LONG
CDECL
X11DRV_GetBitmapBits
(
HBITMAP
hbitmap
,
void
*
bits
,
LONG
count
);
extern
LONG
CDECL
X11DRV_GetBitmapBits
(
HBITMAP
hbitmap
,
void
*
bits
,
LONG
count
);
...
@@ -198,10 +199,6 @@ extern BOOL CDECL X11DRV_GetCharWidth( X11DRV_PDEVICE *physDev, UINT firstChar,
...
@@ -198,10 +199,6 @@ extern BOOL CDECL X11DRV_GetCharWidth( X11DRV_PDEVICE *physDev, UINT firstChar,
extern
BOOL
CDECL
X11DRV_GetTextExtentExPoint
(
X11DRV_PDEVICE
*
physDev
,
LPCWSTR
str
,
INT
count
,
extern
BOOL
CDECL
X11DRV_GetTextExtentExPoint
(
X11DRV_PDEVICE
*
physDev
,
LPCWSTR
str
,
INT
count
,
INT
maxExt
,
LPINT
lpnFit
,
LPINT
alpDx
,
LPSIZE
size
);
INT
maxExt
,
LPINT
lpnFit
,
LPINT
alpDx
,
LPSIZE
size
);
extern
BOOL
CDECL
X11DRV_GetTextMetrics
(
X11DRV_PDEVICE
*
physDev
,
TEXTMETRICW
*
metrics
);
extern
BOOL
CDECL
X11DRV_GetTextMetrics
(
X11DRV_PDEVICE
*
physDev
,
TEXTMETRICW
*
metrics
);
extern
BOOL
CDECL
X11DRV_StretchBlt
(
X11DRV_PDEVICE
*
physDevDst
,
INT
xDst
,
INT
yDst
,
INT
widthDst
,
INT
heightDst
,
X11DRV_PDEVICE
*
physDevSrc
,
INT
xSrc
,
INT
ySrc
,
INT
widthSrc
,
INT
heightSrc
,
DWORD
rop
);
extern
BOOL
CDECL
X11DRV_LineTo
(
X11DRV_PDEVICE
*
physDev
,
INT
x
,
INT
y
);
extern
BOOL
CDECL
X11DRV_LineTo
(
X11DRV_PDEVICE
*
physDev
,
INT
x
,
INT
y
);
extern
BOOL
CDECL
X11DRV_Arc
(
X11DRV_PDEVICE
*
physDev
,
INT
left
,
INT
top
,
INT
right
,
extern
BOOL
CDECL
X11DRV_Arc
(
X11DRV_PDEVICE
*
physDev
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
,
INT
xstart
,
INT
ystart
,
INT
xend
,
INT
yend
);
INT
bottom
,
INT
xstart
,
INT
ystart
,
INT
xend
,
INT
yend
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment