gdiplus: Use clip region in GdipDrawPath.
This commit is contained in:
parent
a90fee9f3d
commit
08b650202c
|
@ -3342,6 +3342,7 @@ GpStatus WINGDIPAPI GdipDrawPath(GpGraphics *graphics, GpPen *pen, GpPath *path)
|
|||
{
|
||||
INT save_state;
|
||||
GpStatus retval;
|
||||
HRGN hrgn=NULL;
|
||||
|
||||
TRACE("(%p, %p, %p)\n", graphics, pen, path);
|
||||
|
||||
|
@ -3359,10 +3360,20 @@ GpStatus WINGDIPAPI GdipDrawPath(GpGraphics *graphics, GpPen *pen, GpPath *path)
|
|||
|
||||
save_state = prepare_dc(graphics, pen);
|
||||
|
||||
retval = get_clip_hrgn(graphics, &hrgn);
|
||||
|
||||
if (retval != Ok)
|
||||
goto end;
|
||||
|
||||
if (hrgn)
|
||||
ExtSelectClipRgn(graphics->hdc, hrgn, RGN_AND);
|
||||
|
||||
retval = draw_poly(graphics, pen, path->pathdata.Points,
|
||||
path->pathdata.Types, path->pathdata.Count, TRUE);
|
||||
|
||||
end:
|
||||
restore_dc(graphics, save_state);
|
||||
DeleteObject(hrgn);
|
||||
|
||||
return retval;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue