X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fmodules%2Fswfdraw.c;h=66f169c30f34dfdba2abd5584829878a90fd8ee0;hb=8526dcf3a698c688e2cc4430ae106b5ecf70677f;hp=66dfc7f33d30aa1db8ce5928cf33c01efcf94db4;hpb=ebf53a918174ecce8bf0ff64fa69e12677e52bae;p=swftools.git diff --git a/lib/modules/swfdraw.c b/lib/modules/swfdraw.c index 66dfc7f..66f169c 100644 --- a/lib/modules/swfdraw.c +++ b/lib/modules/swfdraw.c @@ -23,8 +23,7 @@ static void swf_ShapeDrawerClear(drawer_t*draw); static void swf_ShapeDrawerInit(drawer_t*draw, TAG*tag, int fillstylebits, int linestylebits) { - SWFSHAPEDRAWER*sdraw = malloc(sizeof(SWFSHAPEDRAWER)); - memset(sdraw, 0, sizeof(SWFSHAPEDRAWER)); + SWFSHAPEDRAWER*sdraw = rfx_calloc(sizeof(SWFSHAPEDRAWER)); draw->internal = sdraw; draw->setLineStyle = swf_ShapeDrawerSetLineStyle; @@ -98,13 +97,22 @@ static void swf_ShapeDrawerMoveTo(drawer_t*draw, FPOINT * to) SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; int x = to->x*20; int y = to->y*20; - if(sdraw->lastx != x || sdraw->lasty != y) { + + /* we need to write moveto always- it + might be that it signals the end of a polygon, otherwise + we would end up connecting two polygons which should + be seperate + TODO: check if the last operation was a moveTo- if + yes we *can* skip it. + */ + + //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) { @@ -151,6 +159,8 @@ static void swf_ShapeDrawerSplineTo(drawer_t*draw, FPOINT * c1, FPOINT* to) static void swf_ShapeDrawerFinish(drawer_t*draw) { SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; + if(sdraw->isfinished) + return; fixEndPoint(draw); @@ -173,7 +183,7 @@ static void swf_ShapeDrawerClear(drawer_t*draw) swf_ShapeFree(sdraw->shape); sdraw->shape = 0; - free(draw->internal); + rfx_free(draw->internal); draw->internal = 0; } @@ -186,14 +196,14 @@ SRECT swf_ShapeDrawerGetBBox(drawer_t*draw) SHAPE* swf_ShapeDrawerToShape(drawer_t*draw) { SWFSHAPEDRAWER*sdraw = (SWFSHAPEDRAWER*)draw->internal; - SHAPE* shape = malloc(sizeof(SHAPE)); + SHAPE* shape = rfx_alloc(sizeof(SHAPE)); if(!sdraw->isfinished) { fprintf(stderr, "Warning: you should Finish() your drawer before calling DrawerToShape"); swf_ShapeDrawerFinish(draw); } memcpy(shape, sdraw->shape, sizeof(SHAPE)); shape->bitlen = (sdraw->tag->len-1)*8; - shape->data = (U8*)malloc(sdraw->tag->len-1); + shape->data = (U8*)rfx_alloc(sdraw->tag->len-1); memcpy(shape->data, &sdraw->tag->data[1], sdraw->tag->len-1); return shape; }