From 19c7bc67ec99913b1f0ec52c5f98d56ef0345c3b Mon Sep 17 00:00:00 2001 From: kramm Date: Thu, 5 Feb 2004 13:44:10 +0000 Subject: [PATCH] fix for closing unclosed shapes automatically --- lib/modules/swfdraw.c | 29 +++++++++++++++++++++++++---- 1 file changed, 25 insertions(+), 4 deletions(-) diff --git a/lib/modules/swfdraw.c b/lib/modules/swfdraw.c index b54a0e4..f9a2882 100644 --- a/lib/modules/swfdraw.c +++ b/lib/modules/swfdraw.c @@ -5,6 +5,8 @@ typedef struct _SWFSHAPEDRAWER SHAPE*shape; TAG*tag; int tagfree; + SCOORD firstx; + SCOORD firsty; SCOORD lastx; SCOORD lasty; SRECT bbox; @@ -73,15 +75,31 @@ static void swf_ShapeDrawerSetFillStyle(drawer_t*draw, void*style) { SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; } +static void fixEndPoint(drawer_t*draw) +{ + SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; + if( sdraw->firstx != sdraw->lastx + || sdraw->firsty != sdraw->lasty) { + /* fix non-closing shapes */ + /* TODO: do this only if the shape is filled */ + FPOINT to; + to.x = sdraw->firstx/20.0; + to.y = sdraw->firsty/20.0; + draw->lineTo(draw, &to); + } +} static void swf_ShapeDrawerMoveTo(drawer_t*draw, FPOINT * to) { SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; int x = to->x*20; int y = to->y*20; - swf_ShapeSetMove(sdraw->tag,sdraw->shape,x,y); - sdraw->lastx = x; - sdraw->lasty = y; - draw->pos = *to; + if(sdraw->lastx != x || sdraw->lasty != y) { + fixEndPoint(draw); + swf_ShapeSetMove(sdraw->tag,sdraw->shape,x,y); + sdraw->firstx = sdraw->lastx = x; + sdraw->firsty = sdraw->lasty = y; + draw->pos = *to; + } } static void swf_ShapeDrawerLineTo(drawer_t*draw, FPOINT * to) { @@ -128,6 +146,9 @@ static void swf_ShapeDrawerSplineTo(drawer_t*draw, FPOINT * c1, FPOINT* to) static void swf_ShapeDrawerFinish(drawer_t*draw) { SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; + + fixEndPoint(draw); + if(sdraw->bbox.xmin == SCOORD_MAX) { /* no points at all -> empty bounding box */ sdraw->bbox.xmin = sdraw->bbox.ymin = -- 1.7.10.4