Commit 0cbec550 authored by Vincent Povirk's avatar Vincent Povirk Committed by Alexandre Julliard

gdiplus: Implement drawing metafiles with an emf handle.

parent 954b4938
...@@ -3085,6 +3085,13 @@ GpStatus WINGDIPAPI GdipDrawImagePointsI(GpGraphics *graphics, GpImage *image, ...@@ -3085,6 +3085,13 @@ GpStatus WINGDIPAPI GdipDrawImagePointsI(GpGraphics *graphics, GpImage *image,
return GdipDrawImagePoints(graphics, image, ptf, count); return GdipDrawImagePoints(graphics, image, ptf, count);
} }
static BOOL CALLBACK play_metafile_proc(EmfPlusRecordType record_type, unsigned int flags,
unsigned int dataSize, const unsigned char *pStr, void *userdata)
{
GdipPlayMetafileRecord(userdata, record_type, flags, dataSize, pStr);
return TRUE;
}
GpStatus WINGDIPAPI GdipDrawImagePointsRect(GpGraphics *graphics, GpImage *image, GpStatus WINGDIPAPI GdipDrawImagePointsRect(GpGraphics *graphics, GpImage *image,
GDIPCONST GpPointF *points, INT count, REAL srcx, REAL srcy, REAL srcwidth, GDIPCONST GpPointF *points, INT count, REAL srcx, REAL srcy, REAL srcwidth,
REAL srcheight, GpUnit srcUnit, GDIPCONST GpImageAttributes* imageAttributes, REAL srcheight, GpUnit srcUnit, GDIPCONST GpImageAttributes* imageAttributes,
...@@ -3379,10 +3386,22 @@ GpStatus WINGDIPAPI GdipDrawImagePointsRect(GpGraphics *graphics, GpImage *image ...@@ -3379,10 +3386,22 @@ GpStatus WINGDIPAPI GdipDrawImagePointsRect(GpGraphics *graphics, GpImage *image
DeleteObject(hbitmap); DeleteObject(hbitmap);
} }
} }
else if (image->type == ImageTypeMetafile && ((GpMetafile*)image)->hemf)
{
GpRectF rc;
rc.X = srcx;
rc.Y = srcy;
rc.Width = srcwidth;
rc.Height = srcheight;
return GdipEnumerateMetafileSrcRectDestPoints(graphics, (GpMetafile*)image,
points, count, &rc, srcUnit, play_metafile_proc, image, imageAttributes);
}
else else
{ {
ERR("GpImage with no IPicture or HBITMAP?!\n"); WARN("GpImage with nothing we can draw (metafile in wrong state?)\n");
return NotImplemented; return InvalidParameter;
} }
return Ok; return Ok;
......
...@@ -431,7 +431,7 @@ static void test_getdc(void) ...@@ -431,7 +431,7 @@ static void test_getdc(void)
stat = GdipDrawImagePointsRect(graphics, (GpImage*)metafile, dst_points, 3, stat = GdipDrawImagePointsRect(graphics, (GpImage*)metafile, dst_points, 3,
0.0, 0.0, 100.0, 100.0, UnitPixel, NULL, NULL, NULL); 0.0, 0.0, 100.0, 100.0, UnitPixel, NULL, NULL, NULL);
todo_wine expect(Ok, stat); expect(Ok, stat);
stat = GdipBitmapGetPixel(bitmap, 15, 15, &color); stat = GdipBitmapGetPixel(bitmap, 15, 15, &color);
expect(Ok, stat); expect(Ok, stat);
...@@ -439,7 +439,7 @@ static void test_getdc(void) ...@@ -439,7 +439,7 @@ static void test_getdc(void)
stat = GdipBitmapGetPixel(bitmap, 50, 50, &color); stat = GdipBitmapGetPixel(bitmap, 50, 50, &color);
expect(Ok, stat); expect(Ok, stat);
todo_wine expect(0xff0000ff, color); expect(0xff0000ff, color);
stat = GdipDeleteGraphics(graphics); stat = GdipDeleteGraphics(graphics);
expect(Ok, stat); expect(Ok, stat);
...@@ -550,7 +550,7 @@ static void test_emfonly(void) ...@@ -550,7 +550,7 @@ static void test_emfonly(void)
stat = GdipDrawImagePointsRect(graphics, (GpImage*)metafile, dst_points, 3, stat = GdipDrawImagePointsRect(graphics, (GpImage*)metafile, dst_points, 3,
0.0, 0.0, 100.0, 100.0, UnitPixel, NULL, NULL, NULL); 0.0, 0.0, 100.0, 100.0, UnitPixel, NULL, NULL, NULL);
todo_wine expect(Ok, stat); expect(Ok, stat);
stat = GdipBitmapGetPixel(bitmap, 15, 15, &color); stat = GdipBitmapGetPixel(bitmap, 15, 15, &color);
expect(Ok, stat); expect(Ok, stat);
...@@ -558,7 +558,7 @@ static void test_emfonly(void) ...@@ -558,7 +558,7 @@ static void test_emfonly(void)
stat = GdipBitmapGetPixel(bitmap, 50, 50, &color); stat = GdipBitmapGetPixel(bitmap, 50, 50, &color);
expect(Ok, stat); expect(Ok, stat);
todo_wine expect(0xff0000ff, color); expect(0xff0000ff, color);
stat = GdipDeleteGraphics(graphics); stat = GdipDeleteGraphics(graphics);
expect(Ok, stat); expect(Ok, stat);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment