Commit 9c60a57a authored by Nikolay Sivov's avatar Nikolay Sivov Committed by Alexandre Julliard

gdiplus: Fix curve closing in GdipDrawClosedCurve2.

parent 72304d83
...@@ -1102,7 +1102,7 @@ GpStatus WINGDIPAPI GdipDrawClosedCurveI(GpGraphics *graphics, GpPen *pen, ...@@ -1102,7 +1102,7 @@ GpStatus WINGDIPAPI GdipDrawClosedCurveI(GpGraphics *graphics, GpPen *pen,
GpStatus WINGDIPAPI GdipDrawClosedCurve2(GpGraphics *graphics, GpPen *pen, GpStatus WINGDIPAPI GdipDrawClosedCurve2(GpGraphics *graphics, GpPen *pen,
GDIPCONST GpPointF *points, INT count, REAL tension) GDIPCONST GpPointF *points, INT count, REAL tension)
{ {
GpPointF *ptf; GpPath *path;
GpStatus stat; GpStatus stat;
TRACE("(%p, %p, %p, %d, %.2f)\n", graphics, pen, points, count, tension); TRACE("(%p, %p, %p, %d, %.2f)\n", graphics, pen, points, count, tension);
...@@ -1113,18 +1113,18 @@ GpStatus WINGDIPAPI GdipDrawClosedCurve2(GpGraphics *graphics, GpPen *pen, ...@@ -1113,18 +1113,18 @@ GpStatus WINGDIPAPI GdipDrawClosedCurve2(GpGraphics *graphics, GpPen *pen,
if(graphics->busy) if(graphics->busy)
return ObjectBusy; return ObjectBusy;
/* make a full points copy.. */ if((stat = GdipCreatePath(FillModeAlternate, &path)) != Ok)
ptf = GdipAlloc(sizeof(GpPointF)*(count+1)); return stat;
if(!ptf)
return OutOfMemory;
memcpy(ptf, points, sizeof(GpPointF)*count);
/* ..and add a first point as a last one */ stat = GdipAddPathClosedCurve2(path, points, count, tension);
ptf[count] = ptf[0]; if(stat != Ok){
GdipDeletePath(path);
return stat;
}
stat = GdipDrawCurve2(graphics, pen, ptf, count + 1, tension); stat = GdipDrawPath(graphics, pen, path);
GdipFree(ptf); GdipDeletePath(path);
return stat; return 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