gdiplus: Account for gdi32 transform in GdipSetClipHrgn.

Signed-off-by: Vincent Povirk <vincent@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Vincent Povirk 2017-09-05 13:43:33 -05:00 committed by Alexandre Julliard
parent 9e1c110585
commit b32c324378
2 changed files with 59 additions and 5 deletions

View File

@ -6209,6 +6209,7 @@ GpStatus WINGDIPAPI GdipSetClipHrgn(GpGraphics *graphics, HRGN hrgn, CombineMode
{
GpRegion *region;
GpStatus status;
GpMatrix transform;
TRACE("(%p, %p, %d)\n", graphics, hrgn, mode);
@ -6218,14 +6219,21 @@ GpStatus WINGDIPAPI GdipSetClipHrgn(GpGraphics *graphics, HRGN hrgn, CombineMode
if(graphics->busy)
return ObjectBusy;
/* hrgn is already in device units */
/* hrgn is in gdi32 device units */
status = GdipCreateRegionHrgn(hrgn, &region);
if(status != Ok)
return status;
status = GdipCombineRegionRegion(graphics->clip, region, mode);
if (status == Ok)
{
status = get_graphics_transform(graphics, CoordinateSpaceDevice, WineCoordinateSpaceGdiDevice, &transform);
GdipDeleteRegion(region);
if (status == Ok)
status = GdipTransformRegion(region, &transform);
if (status == Ok)
status = GdipCombineRegionRegion(graphics->clip, region, mode);
GdipDeleteRegion(region);
}
return status;
}

View File

@ -6529,6 +6529,51 @@ static void test_GdipDrawImagePointsRectOnMemoryDC(void)
ReleaseDC(hwnd, dc);
}
static void test_cliphrgn_transform(void)
{
HDC hdc;
GpStatus status;
GpGraphics *graphics;
HRGN rgn;
RectF rectf;
BOOL res;
hdc = GetDC(hwnd);
SetViewportOrgEx(hdc, 10, 10, NULL);
status = GdipCreateFromHDC(hdc, &graphics);
expect(Ok, status);
rgn = CreateRectRgn(0, 0, 100, 100);
status = GdipSetClipHrgn(graphics, rgn, CombineModeReplace);
expect(Ok, status);
status = GdipGetVisibleClipBounds(graphics, &rectf);
expect(Ok, status);
expectf(-10.0, rectf.X);
expectf(-10.0, rectf.Y);
expectf(100.0, rectf.Width);
expectf(100.0, rectf.Height);
status = GdipIsVisiblePoint(graphics, 95, 95, &res);
expect(Ok, status);
expect(FALSE, res);
status = GdipIsVisiblePoint(graphics, -5, -5, &res);
expect(Ok, status);
expect(TRUE, res);
DeleteObject(rgn);
GdipDeleteGraphics(graphics);
SetViewportOrgEx(hdc, 0, 0, NULL);
ReleaseDC(hwnd, hdc);
}
START_TEST(graphics)
{
struct GdiplusStartupInput gdiplusStartupInput;
@ -6618,6 +6663,7 @@ START_TEST(graphics)
test_GdipDrawImagePointsRectOnMemoryDC();
test_container_rects();
test_GdipGraphicsSetAbort();
test_cliphrgn_transform();
GdiplusShutdown(gdiplusToken);
DestroyWindow( hwnd );