Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
e95cff03
Commit
e95cff03
authored
Sep 20, 2012
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
gdi32: Always update the DC before looking for the physdev pointer.
parent
7eb0d62b
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
105 additions
and
118 deletions
+105
-118
bitblt.c
dlls/gdi32/bitblt.c
+19
-12
clipping.c
dlls/gdi32/clipping.c
+16
-20
dc.c
dlls/gdi32/dc.c
+2
-1
dib.c
dlls/gdi32/dib.c
+4
-2
driver.c
dlls/gdi32/driver.c
+4
-5
painting.c
dlls/gdi32/painting.c
+60
-78
No files found.
dlls/gdi32/bitblt.c
View file @
e95cff03
...
...
@@ -518,7 +518,6 @@ BOOL WINAPI PatBlt( HDC hdc, INT left, INT top, INT width, INT height, DWORD rop
if
((
dc
=
get_dc_ptr
(
hdc
)))
{
struct
bitblt_coords
dst
;
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPatBlt
);
update_dc
(
dc
);
...
...
@@ -538,8 +537,11 @@ BOOL WINAPI PatBlt( HDC hdc, INT left, INT top, INT width, INT height, DWORD rop
hdc
,
dst
.
log_x
,
dst
.
log_y
,
dst
.
log_width
,
dst
.
log_height
,
dst
.
x
,
dst
.
y
,
dst
.
width
,
dst
.
height
,
wine_dbgstr_rect
(
&
dst
.
visrect
),
rop
);
if
(
!
ret
)
ret
=
physdev
->
funcs
->
pPatBlt
(
physdev
,
&
dst
,
rop
);
if
(
!
ret
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPatBlt
);
ret
=
physdev
->
funcs
->
pPatBlt
(
physdev
,
&
dst
,
rop
);
}
release_dc_ptr
(
dc
);
}
return
ret
;
...
...
@@ -574,8 +576,6 @@ BOOL WINAPI StretchBlt( HDC hdcDst, INT xDst, INT yDst, INT widthDst, INT height
if
((
dcSrc
=
get_dc_ptr
(
hdcSrc
)))
{
struct
bitblt_coords
src
,
dst
;
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pStretchBlt
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pStretchBlt
);
update_dc
(
dcSrc
);
update_dc
(
dcDst
);
...
...
@@ -604,7 +604,12 @@ BOOL WINAPI StretchBlt( HDC hdcDst, INT xDst, INT yDst, INT widthDst, INT height
hdcDst
,
dst
.
log_x
,
dst
.
log_y
,
dst
.
log_width
,
dst
.
log_height
,
dst
.
x
,
dst
.
y
,
dst
.
width
,
dst
.
height
,
wine_dbgstr_rect
(
&
dst
.
visrect
),
rop
);
if
(
!
ret
)
ret
=
dst_dev
->
funcs
->
pStretchBlt
(
dst_dev
,
&
dst
,
src_dev
,
&
src
,
rop
);
if
(
!
ret
)
{
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pStretchBlt
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pStretchBlt
);
ret
=
dst_dev
->
funcs
->
pStretchBlt
(
dst_dev
,
&
dst
,
src_dev
,
&
src
,
rop
);
}
release_dc_ptr
(
dcSrc
);
}
release_dc_ptr
(
dcDst
);
...
...
@@ -911,8 +916,6 @@ BOOL WINAPI GdiAlphaBlend(HDC hdcDst, int xDst, int yDst, int widthDst, int heig
if
((
dcDst
=
get_dc_ptr
(
hdcDst
)))
{
struct
bitblt_coords
src
,
dst
;
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pAlphaBlend
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pAlphaBlend
);
update_dc
(
dcSrc
);
update_dc
(
dcDst
);
...
...
@@ -921,12 +924,12 @@ BOOL WINAPI GdiAlphaBlend(HDC hdcDst, int xDst, int yDst, int widthDst, int heig
src
.
log_y
=
ySrc
;
src
.
log_width
=
widthSrc
;
src
.
log_height
=
heightSrc
;
src
.
layout
=
GetLayout
(
src_dev
->
hd
c
);
src
.
layout
=
GetLayout
(
hdcSr
c
);
dst
.
log_x
=
xDst
;
dst
.
log_y
=
yDst
;
dst
.
log_width
=
widthDst
;
dst
.
log_height
=
heightDst
;
dst
.
layout
=
GetLayout
(
dst_dev
->
hdc
);
dst
.
layout
=
GetLayout
(
hdcDst
);
ret
=
!
get_vis_rectangles
(
dcDst
,
&
dst
,
dcSrc
,
&
src
);
TRACE
(
"src %p log=%d,%d %dx%d phys=%d,%d %dx%d vis=%s dst %p log=%d,%d %dx%d phys=%d,%d %dx%d vis=%s blend=%02x/%02x/%02x/%02x
\n
"
,
...
...
@@ -962,8 +965,12 @@ BOOL WINAPI GdiAlphaBlend(HDC hdcDst, int xDst, int yDst, int widthDst, int heig
SetLastError
(
ERROR_INVALID_PARAMETER
);
ret
=
FALSE
;
}
else
if
(
!
ret
)
ret
=
dst_dev
->
funcs
->
pAlphaBlend
(
dst_dev
,
&
dst
,
src_dev
,
&
src
,
blendFunction
);
else
if
(
!
ret
)
{
PHYSDEV
src_dev
=
GET_DC_PHYSDEV
(
dcSrc
,
pAlphaBlend
);
PHYSDEV
dst_dev
=
GET_DC_PHYSDEV
(
dcDst
,
pAlphaBlend
);
ret
=
dst_dev
->
funcs
->
pAlphaBlend
(
dst_dev
,
&
dst
,
src_dev
,
&
src
,
blendFunction
);
}
release_dc_ptr
(
dcDst
);
}
release_dc_ptr
(
dcSrc
);
...
...
dlls/gdi32/clipping.c
View file @
e95cff03
...
...
@@ -250,18 +250,17 @@ INT WINAPI SelectClipRgn( HDC hdc, HRGN hrgn )
*/
INT
WINAPI
ExtSelectClipRgn
(
HDC
hdc
,
HRGN
hrgn
,
INT
fnMode
)
{
INT
retval
=
ERROR
;
PHYSDEV
physdev
;
INT
retval
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
TRACE
(
"%p %p %d
\n
"
,
hdc
,
hrgn
,
fnMode
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtSelectClipRgn
);
if
(
!
dc
)
return
ERROR
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtSelectClipRgn
);
retval
=
physdev
->
funcs
->
pExtSelectClipRgn
(
physdev
,
hrgn
,
fnMode
);
release_dc_ptr
(
dc
);
}
return
retval
;
}
...
...
@@ -298,18 +297,17 @@ void CDECL __wine_set_visible_region( HDC hdc, HRGN hrgn, const RECT *vis_rect,
*/
INT
WINAPI
OffsetClipRgn
(
HDC
hdc
,
INT
x
,
INT
y
)
{
INT
ret
=
ERROR
;
PHYSDEV
physdev
;
INT
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
TRACE
(
"%p %d,%d
\n
"
,
hdc
,
x
,
y
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pOffsetClipRgn
);
if
(
!
dc
)
return
ERROR
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pOffsetClipRgn
);
ret
=
physdev
->
funcs
->
pOffsetClipRgn
(
physdev
,
x
,
y
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -320,18 +318,17 @@ INT WINAPI OffsetClipRgn( HDC hdc, INT x, INT y )
INT
WINAPI
ExcludeClipRect
(
HDC
hdc
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
)
{
INT
ret
=
ERROR
;
PHYSDEV
physdev
;
INT
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
TRACE
(
"%p %d,%d-%d,%d
\n
"
,
hdc
,
left
,
top
,
right
,
bottom
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExcludeClipRect
);
if
(
!
dc
)
return
ERROR
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExcludeClipRect
);
ret
=
physdev
->
funcs
->
pExcludeClipRect
(
physdev
,
left
,
top
,
right
,
bottom
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -341,18 +338,17 @@ INT WINAPI ExcludeClipRect( HDC hdc, INT left, INT top,
*/
INT
WINAPI
IntersectClipRect
(
HDC
hdc
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
)
{
INT
ret
=
ERROR
;
PHYSDEV
physdev
;
INT
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
TRACE
(
"%p %d,%d - %d,%d
\n
"
,
hdc
,
left
,
top
,
right
,
bottom
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pIntersectClipRect
);
if
(
!
dc
)
return
ERROR
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pIntersectClipRect
);
ret
=
physdev
->
funcs
->
pIntersectClipRect
(
physdev
,
left
,
top
,
right
,
bottom
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
dlls/gdi32/dc.c
View file @
e95cff03
...
...
@@ -537,14 +537,15 @@ INT WINAPI SaveDC( HDC hdc )
*/
BOOL
WINAPI
RestoreDC
(
HDC
hdc
,
INT
level
)
{
PHYSDEV
physdev
;
DC
*
dc
;
BOOL
success
=
FALSE
;
TRACE
(
"%p %d
\n
"
,
hdc
,
level
);
if
((
dc
=
get_dc_ptr
(
hdc
)))
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRestoreDC
);
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRestoreDC
);
success
=
physdev
->
funcs
->
pRestoreDC
(
physdev
,
level
);
release_dc_ptr
(
dc
);
}
...
...
dlls/gdi32/dib.c
View file @
e95cff03
...
...
@@ -603,6 +603,7 @@ INT WINAPI StretchDIBits(HDC hdc, INT xDst, INT yDst, INT widthDst, INT heightDs
{
char
buffer
[
FIELD_OFFSET
(
BITMAPINFO
,
bmiColors
[
256
]
)];
BITMAPINFO
*
info
=
(
BITMAPINFO
*
)
buffer
;
PHYSDEV
physdev
;
DC
*
dc
;
INT
ret
=
0
;
...
...
@@ -615,8 +616,8 @@ INT WINAPI StretchDIBits(HDC hdc, INT xDst, INT yDst, INT widthDst, INT heightDs
if
((
dc
=
get_dc_ptr
(
hdc
)))
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pStretchDIBits
);
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pStretchDIBits
);
ret
=
physdev
->
funcs
->
pStretchDIBits
(
physdev
,
xDst
,
yDst
,
widthDst
,
heightDst
,
xSrc
,
ySrc
,
widthSrc
,
heightSrc
,
bits
,
info
,
coloruse
,
rop
);
release_dc_ptr
(
dc
);
...
...
@@ -875,6 +876,7 @@ INT WINAPI SetDIBitsToDevice(HDC hdc, INT xDest, INT yDest, DWORD cx,
{
char
buffer
[
FIELD_OFFSET
(
BITMAPINFO
,
bmiColors
[
256
]
)];
BITMAPINFO
*
info
=
(
BITMAPINFO
*
)
buffer
;
PHYSDEV
physdev
;
INT
ret
=
0
;
DC
*
dc
;
...
...
@@ -887,8 +889,8 @@ INT WINAPI SetDIBitsToDevice(HDC hdc, INT xDest, INT yDest, DWORD cx,
if
((
dc
=
get_dc_ptr
(
hdc
)))
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetDIBitsToDevice
);
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetDIBitsToDevice
);
ret
=
physdev
->
funcs
->
pSetDIBitsToDevice
(
physdev
,
xDest
,
yDest
,
cx
,
cy
,
xSrc
,
ySrc
,
startscan
,
lines
,
bits
,
info
,
coloruse
);
release_dc_ptr
(
dc
);
...
...
dlls/gdi32/driver.c
View file @
e95cff03
...
...
@@ -1121,16 +1121,15 @@ INT WINAPI Escape( HDC hdc, INT escape, INT in_count, LPCSTR in_data, LPVOID out
INT
WINAPI
ExtEscape
(
HDC
hdc
,
INT
nEscape
,
INT
cbInput
,
LPCSTR
lpszInData
,
INT
cbOutput
,
LPSTR
lpszOutData
)
{
INT
ret
=
0
;
PHYSDEV
physdev
;
INT
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtEscape
);
if
(
!
dc
)
return
0
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtEscape
);
ret
=
physdev
->
funcs
->
pExtEscape
(
physdev
,
nEscape
,
cbInput
,
lpszInData
,
cbOutput
,
lpszOutData
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
dlls/gdi32/painting.c
View file @
e95cff03
...
...
@@ -282,16 +282,15 @@ BOOL WINAPI Arc( HDC hdc, INT left, INT top, INT right,
INT
bottom
,
INT
xstart
,
INT
ystart
,
INT
xend
,
INT
yend
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pArc
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pArc
);
ret
=
physdev
->
funcs
->
pArc
(
physdev
,
left
,
top
,
right
,
bottom
,
xstart
,
ystart
,
xend
,
yend
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -396,16 +395,15 @@ BOOL WINAPI Ellipse( HDC hdc, INT left, INT top,
BOOL
WINAPI
Rectangle
(
HDC
hdc
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRectangle
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRectangle
);
ret
=
physdev
->
funcs
->
pRectangle
(
physdev
,
left
,
top
,
right
,
bottom
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -416,16 +414,15 @@ BOOL WINAPI Rectangle( HDC hdc, INT left, INT top,
BOOL
WINAPI
RoundRect
(
HDC
hdc
,
INT
left
,
INT
top
,
INT
right
,
INT
bottom
,
INT
ell_width
,
INT
ell_height
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRoundRect
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pRoundRect
);
ret
=
physdev
->
funcs
->
pRoundRect
(
physdev
,
left
,
top
,
right
,
bottom
,
ell_width
,
ell_height
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -434,16 +431,15 @@ BOOL WINAPI RoundRect( HDC hdc, INT left, INT top, INT right,
*/
COLORREF
WINAPI
SetPixel
(
HDC
hdc
,
INT
x
,
INT
y
,
COLORREF
color
)
{
COLORREF
ret
=
0
;
PHYSDEV
physdev
;
COLORREF
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetPixel
);
if
(
!
dc
)
return
0
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetPixel
);
ret
=
physdev
->
funcs
->
pSetPixel
(
physdev
,
x
,
y
,
color
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -452,18 +448,15 @@ COLORREF WINAPI SetPixel( HDC hdc, INT x, INT y, COLORREF color )
*/
BOOL
WINAPI
SetPixelV
(
HDC
hdc
,
INT
x
,
INT
y
,
COLORREF
color
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetPixel
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pSetPixel
);
physdev
->
funcs
->
pSetPixel
(
physdev
,
x
,
y
,
color
);
ret
=
TRUE
;
release_dc_ptr
(
dc
);
}
return
ret
;
return
TRUE
;
}
/***********************************************************************
...
...
@@ -471,16 +464,15 @@ BOOL WINAPI SetPixelV( HDC hdc, INT x, INT y, COLORREF color )
*/
COLORREF
WINAPI
GetPixel
(
HDC
hdc
,
INT
x
,
INT
y
)
{
COLORREF
ret
=
CLR_INVALID
;
PHYSDEV
physdev
;
COLORREF
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pGetPixel
);
if
(
!
dc
)
return
CLR_INVALID
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pGetPixel
);
ret
=
physdev
->
funcs
->
pGetPixel
(
physdev
,
x
,
y
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -535,16 +527,15 @@ BOOL WINAPI GdiSwapBuffers( HDC hdc )
*/
BOOL
WINAPI
PaintRgn
(
HDC
hdc
,
HRGN
hrgn
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPaintRgn
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPaintRgn
);
ret
=
physdev
->
funcs
->
pPaintRgn
(
physdev
,
hrgn
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -554,16 +545,15 @@ BOOL WINAPI PaintRgn( HDC hdc, HRGN hrgn )
*/
BOOL
WINAPI
FillRgn
(
HDC
hdc
,
HRGN
hrgn
,
HBRUSH
hbrush
)
{
BOOL
retval
=
FALSE
;
PHYSDEV
physdev
;
BOOL
retval
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pFillRgn
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pFillRgn
);
retval
=
physdev
->
funcs
->
pFillRgn
(
physdev
,
hrgn
,
hbrush
);
release_dc_ptr
(
dc
);
}
return
retval
;
}
...
...
@@ -574,16 +564,15 @@ BOOL WINAPI FillRgn( HDC hdc, HRGN hrgn, HBRUSH hbrush )
BOOL
WINAPI
FrameRgn
(
HDC
hdc
,
HRGN
hrgn
,
HBRUSH
hbrush
,
INT
nWidth
,
INT
nHeight
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pFrameRgn
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pFrameRgn
);
ret
=
physdev
->
funcs
->
pFrameRgn
(
physdev
,
hrgn
,
hbrush
,
nWidth
,
nHeight
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -593,16 +582,15 @@ BOOL WINAPI FrameRgn( HDC hdc, HRGN hrgn, HBRUSH hbrush,
*/
BOOL
WINAPI
InvertRgn
(
HDC
hdc
,
HRGN
hrgn
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pInvertRgn
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pInvertRgn
);
ret
=
physdev
->
funcs
->
pInvertRgn
(
physdev
,
hrgn
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -612,16 +600,15 @@ BOOL WINAPI InvertRgn( HDC hdc, HRGN hrgn )
*/
BOOL
WINAPI
Polyline
(
HDC
hdc
,
const
POINT
*
pt
,
INT
count
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyline
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyline
);
ret
=
physdev
->
funcs
->
pPolyline
(
physdev
,
pt
,
count
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -655,16 +642,15 @@ BOOL WINAPI PolylineTo( HDC hdc, const POINT* pt, DWORD cCount )
*/
BOOL
WINAPI
Polygon
(
HDC
hdc
,
const
POINT
*
pt
,
INT
count
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolygon
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolygon
);
ret
=
physdev
->
funcs
->
pPolygon
(
physdev
,
pt
,
count
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -675,16 +661,15 @@ BOOL WINAPI Polygon( HDC hdc, const POINT* pt, INT count )
BOOL
WINAPI
PolyPolygon
(
HDC
hdc
,
const
POINT
*
pt
,
const
INT
*
counts
,
UINT
polygons
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyPolygon
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyPolygon
);
ret
=
physdev
->
funcs
->
pPolyPolygon
(
physdev
,
pt
,
counts
,
polygons
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -694,16 +679,15 @@ BOOL WINAPI PolyPolygon( HDC hdc, const POINT* pt, const INT* counts,
BOOL
WINAPI
PolyPolyline
(
HDC
hdc
,
const
POINT
*
pt
,
const
DWORD
*
counts
,
DWORD
polylines
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyPolyline
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pPolyPolyline
);
ret
=
physdev
->
funcs
->
pPolyPolyline
(
physdev
,
pt
,
counts
,
polylines
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
@@ -713,17 +697,15 @@ BOOL WINAPI PolyPolyline( HDC hdc, const POINT* pt, const DWORD* counts,
BOOL
WINAPI
ExtFloodFill
(
HDC
hdc
,
INT
x
,
INT
y
,
COLORREF
color
,
UINT
fillType
)
{
BOOL
ret
=
FALSE
;
PHYSDEV
physdev
;
BOOL
ret
;
DC
*
dc
=
get_dc_ptr
(
hdc
);
if
(
dc
)
{
PHYSDEV
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtFloodFill
);
if
(
!
dc
)
return
FALSE
;
update_dc
(
dc
);
physdev
=
GET_DC_PHYSDEV
(
dc
,
pExtFloodFill
);
ret
=
physdev
->
funcs
->
pExtFloodFill
(
physdev
,
x
,
y
,
color
,
fillType
);
release_dc_ptr
(
dc
);
}
return
ret
;
}
...
...
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