X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=pdf2swf%2Fswfoutput.cc;h=19db1a85c01f3c22bbb2f9a6ea6afa40aa186920;hb=dd81e2a404b4b0751289ef06c4a2011037f39267;hp=dea823bd29735b6423c77e6d14f5a67c60d20f73;hpb=d8ef6d637f0c716fcc65515de5d0a58fe13073c5;p=swftools.git diff --git a/pdf2swf/swfoutput.cc b/pdf2swf/swfoutput.cc index dea823b..19db1a8 100644 --- a/pdf2swf/swfoutput.cc +++ b/pdf2swf/swfoutput.cc @@ -35,6 +35,7 @@ extern "C" { #include "../lib/log.h" #include "../lib/rfxswf.h" +#include "../lib/gfxdevice.h" } #define CHARDATAMAX 8192 @@ -56,6 +57,8 @@ struct fontlist_t fontlist_t*next; }; +double config_ppmsubpixels=0; +double config_jpegsubpixels=0; int config_opennewwindow=0; int config_ignoredraworder=0; int config_drawonlyshapes=0; @@ -72,6 +75,8 @@ float config_minlinewidth=0.05; typedef struct _swfoutput_internal { + swfoutput*obj; // the swfoutput object where this internal struct resides + SWF swf; fontlist_t* fontlist; @@ -97,17 +102,27 @@ typedef struct _swfoutput_internal int lastwasfill; int shapeisempty; char fill; - int max_x; - int max_y; + int min_x,max_x; + int min_y,max_y; TAG* cliptags[128]; int clipshapes[128]; U32 clipdepths[128]; int clippos; + /* image cache */ + int pic_xids[1024]; + int pic_yids[1024]; + int pic_ids[1024]; + int pic_width[1024]; + int pic_height[1024]; + int picpos; + int frameno; int lastframeno; char fillstylechanged; + + int jpeg; //next image type int bboxrectpos; SRECT bboxrect; @@ -118,13 +133,20 @@ typedef struct _swfoutput_internal int chardatapos; int firstpage; char pagefinished; + + /* during the transition to the gfxdevice interface: + a device which uses this swfoutput as target */ + gfxdevice_t device; + } swfoutput_internal; + +void swf_fillbitmap(struct _gfxdevice*driver, gfxline_t*line, gfximage_t*img, gfxmatrix_t*move, gfxcxform_t*cxform); +int swf_setparameter(struct _gfxdevice*driver, const char*key, const char*value); static swfoutput_internal* init_internal_struct() { swfoutput_internal*i = (swfoutput_internal*)malloc(sizeof(swfoutput_internal)); memset(i, 0, sizeof(swfoutput_internal)); - i->storefont = 0; i->currentswfid = 0; @@ -152,6 +174,10 @@ static swfoutput_internal* init_internal_struct() i->firstpage = 1; i->pagefinished = 1; + i->device.internal = (void*)i; + i->device.fillbitmap = swf_fillbitmap; + i->device.setparameter = swf_setparameter; + return i; }; @@ -808,12 +834,18 @@ void drawpath2poly(struct swfoutput *obj, SWF_OUTLINE*outline, struct swfmatrix* tmp->last = 0; while(1) { + double previousx = x, previousy = y; if(tmp) { x += (tmp->dest.x/(float)0xffff); y += (tmp->dest.y/(float)0xffff); } if(!tmp || tmp->type == SWF_PATHTYPE_MOVE) { if(valid && last) { + if(fabs(lastx-previousx)<0.001 && fabs(lasty-previousy)<0.001) { + /* endpoints match- the path is closed. + Don't bother to draw endings */ + drawShortPath(obj, lastx, lasty, m, last); + } if(last->type == SWF_PATHTYPE_LINE && t1linelen(obj,last)>line_width*2 && lastwasline && line_cap != LINE_CAP_ROUND) drawShortPathWithStraightEnds(obj, lastx, lasty, m, last, valid, line_cap, line_join, line_width); @@ -828,7 +860,7 @@ void drawpath2poly(struct swfoutput *obj, SWF_OUTLINE*outline, struct swfmatrix* lasty = y; } else { if(!last) - last = tmp; + last = tmp; //remember last stroke start (first segment after moveto) valid++; } @@ -1160,7 +1192,7 @@ static void endtext(swfoutput*obj) swf_SetRect(i->tag,&r); MATRIX m; - swf_GetMatrix(0, &m); + swf_GetMatrix(0, &m); /* set unit matrix- the real matrix is in the placeobject */ swf_SetMatrix(i->tag,&m); putcharacters(obj, i->tag); @@ -1319,7 +1351,7 @@ void swfoutput_setfont(struct swfoutput*obj, char*fontid, char*filename) } } if(bad>5) { - msg(" Font %s has bad unicode mapping", swffont->name); + msg(" Font %s has bad unicode mapping", fontid); swffont->encoding = 255; } } @@ -1507,6 +1539,8 @@ void swfoutput_newpage(struct swfoutput*obj, int pageNum, int movex, int movey, swf_PlaceObjectFree(&obj); } + i->min_x = x1; + i->min_y = y1; i->max_x = x2; i->max_y = y2; @@ -1536,6 +1570,7 @@ void swfoutput_init(struct swfoutput* obj) { memset(obj, 0, sizeof(struct swfoutput)); obj->internal = init_internal_struct(); + ((swfoutput_internal*)obj->internal)->obj = obj; swfoutput_internal*i = (swfoutput_internal*)obj->internal; @@ -1570,7 +1605,6 @@ void swfoutput_init(struct swfoutput* obj) static void startshape(struct swfoutput*obj) { swfoutput_internal*i = (swfoutput_internal*)obj->internal; - RGBA rgb; SRECT r; if(i->textid>=0) @@ -1580,15 +1614,13 @@ static void startshape(struct swfoutput*obj) swf_ShapeNew(&i->shape); i->linestyleid = swf_ShapeAddLineStyle(i->shape,i->linewidth,&obj->strokergb); - rgb.r = obj->fillrgb.r; - rgb.g = obj->fillrgb.g; - rgb.b = obj->fillrgb.b; i->fillstyleid = swf_ShapeAddSolidFillStyle(i->shape,&obj->fillrgb); i->shapeid = ++i->currentswfid; swf_SetU16(i->tag,i->shapeid); // ID i->bboxrectpos = i->tag->len; + /* changed later */ r.xmin = 0; r.ymin = 0; r.xmax = 20*i->max_x; @@ -1718,8 +1750,9 @@ static void endshape(swfoutput*obj, int clipdepth) fixAreas(obj); if(i->shapeisempty || + /*bbox empty?*/ (i->bboxrect.xmin == i->bboxrect.xmax && - i->bboxrect.ymin == i->bboxrect.ymax)) + i->bboxrect.ymin == i->bboxrect.ymax)) { // delete the shape again, we didn't do anything cancelshape(obj); @@ -2076,7 +2109,7 @@ static void drawlink(struct swfoutput*obj, ActionTAG*actions1, ActionTAG*actions if(points[t].x box.xmax) + box.xmax = x; + if(y < box.ymin) + box.ymin = y; + if(y > box.ymax) + box.ymax = y; + return box; +} + +gfxbbox_t gfxline_getbbox(gfxline_t*line) +{ + gfxcoord_t x=0,y=0; + gfxbbox_t bbox = {0,0,0,0}; + char last = 0; + while(line) { + if(line->type == gfx_moveTo) { + last = 1; + } else if(line->type == gfx_lineTo) { + if(last) bbox = gfxbbox_expand_to_point(bbox, x, y); + bbox = gfxbbox_expand_to_point(bbox, line->x, line->y); + last = 0; + } else if(line->type == gfx_splineTo) { + if(last) bbox = gfxbbox_expand_to_point(bbox, x, y); + bbox = gfxbbox_expand_to_point(bbox, line->sx, line->sy); + bbox = gfxbbox_expand_to_point(bbox, line->x, line->y); + last = 0; + } + x = line->x; + y = line->x; + line = line->next; + } + return bbox; +} +/* ---------- */ + +static void drawgfxline(struct swfoutput*obj, gfxline_t*line) { swfoutput_internal*i = (swfoutput_internal*)obj->internal; - RGBA rgb; - SRECT r; - int lsid=0; - int fsid; - struct plotxy p1,p2,p3,p4; - int myshapeid; - double xmax=x1,ymax=y1,xmin=x1,ymin=y1; - if(x2>xmax) xmax=x2; - if(y2>ymax) ymax=y2; - if(x2xmax) xmax=x3; - if(y3>ymax) ymax=y3; - if(x3xmax) xmax=x4; - if(y4>ymax) ymax=y4; - if(x4type == gfx_moveTo) { + moveto(obj, i->tag, line->x, line->y); + } if(line->type == gfx_lineTo) { + lineto(obj, i->tag, line->x, line->y); + } else if(line->type == gfx_splineTo) { + plotxy s,p; + s.x = line->sx;p.x = line->x; + s.y = line->sy;p.y = line->y; + splineto(obj, i->tag, s, p); + } + line = line->next; + } +} +static CXFORM gfxcxform_to_cxform(gfxcxform_t* c) +{ + CXFORM cx; + swf_GetCXForm(0, &cx, 1); + if(!c) + return cx; + if(c->rg!=0 || c->rb!=0 || c->ra!=0 || + c->gr!=0 || c->gb!=0 || c->ga!=0 || + c->br!=0 || c->bg!=0 || c->ba!=0 || + c->ar!=0 || c->ag!=0 || c->ab!=0) + msg(" CXForm not SWF-compatible"); - {p1.x = (int)(p1.x*20)/20.0; - p1.y = (int)(p1.y*20)/20.0; - p2.x = (int)(p2.x*20)/20.0; - p2.y = (int)(p2.y*20)/20.0; - p3.x = (int)(p3.x*20)/20.0; - p3.y = (int)(p3.y*20)/20.0; - p4.x = (int)(p4.x*20)/20.0; - p4.y = (int)(p4.y*20)/20.0;} + cx.a0 = (S16)(c->aa*256); + cx.r0 = (S16)(c->rr*256); + cx.g0 = (S16)(c->gg*256); + cx.b0 = (S16)(c->bb*256); + cx.a1 = c->t.a; + cx.r1 = c->t.r; + cx.g1 = c->t.g; + cx.b1 = c->t.b; + return cx; +} + +static int add_image(swfoutput_internal*i, gfximage_t*img, int targetwidth, int targetheight, int* newwidth, int* newheight) +{ + RGBA*newpic = 0; + RGBA*mem = (RGBA*)img->data; + int bitid = ++i->currentswfid; - MATRIX m; - m.sx = (int)(65536*20*(p4.x-p1.x)/sizex); - m.r1 = -(int)(65536*20*(p4.y-p1.y)/sizex); - m.r0 = (int)(65536*20*(p1.x-p2.x)/sizey); - m.sy = -(int)(65536*20*(p1.y-p2.y)/sizey); + int sizex = img->width; + int sizey = img->height; + int num_colors = swf_ImageGetNumberOfPaletteEntries(mem,sizex,sizey,0); + int has_alpha = swf_ImageHasAlpha(mem,sizex,sizey); + int is_jpeg = i->jpeg; + i->jpeg = 0; + + int newsizex=sizex, newsizey=sizey; + + /// { + if(is_jpeg && config_jpegsubpixels) { + newsizex = (int)(targetwidth*config_jpegsubpixels+0.5); + newsizey = (int)(targetheight*config_jpegsubpixels+0.5); + } else if(!is_jpeg && config_ppmsubpixels) { + newsizex = (int)(targetwidth*config_ppmsubpixels+0.5); + newsizey = (int)(targetheight*config_ppmsubpixels+0.5); + } + /// } + + *newwidth = newsizex; + *newheight = newsizey; + + + /* TODO: cache images */ + + msg(" Drawing %dx%d %s%simage at size %dx%d (%dx%d), %s%d colors", + sizex, sizey, + has_alpha?(has_alpha==2?"semi-transparent ":"transparent "):"", + is_jpeg?"jpeg-":"", + newsizex, newsizey, + targetwidth, targetheight, + /*newsizex, newsizey,*/ + num_colors>256?">":"", num_colors>256?256:num_colors); + + if(newsizex!=sizex || newsizey!=sizey) { + newpic = swf_ImageScale(mem, sizex, sizey, newsizex, newsizey); + sizex = newsizex; + sizey = newsizey; + mem = newpic; + } + + if(has_alpha) { + if(num_colors<=256 || sizex<8 || sizey<8) { + i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSLOSSLESS2); + swf_SetU16(i->tag, bitid); + swf_SetLosslessImage(i->tag,mem,sizex,sizey); + } else { + /*TODO: check what is smaller */ + i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSJPEG3); + swf_SetU16(i->tag, bitid); + swf_SetJPEGBits3(i->tag,sizex,sizey,mem,config_jpegquality); + //swf_SetLosslessImage(i->tag,mem,sizex,sizey); + } + } else { + if(num_colors<=256 || sizex<8) { + i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSLOSSLESS); + swf_SetU16(i->tag, bitid); + swf_SetLosslessImage(i->tag,mem,sizex,sizey); + } else { + /*TODO: check what is smaller */ + i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSJPEG2); + swf_SetU16(i->tag, bitid); + swf_SetJPEGBits2(i->tag,sizex,sizey,mem,config_jpegquality); + //swf_SetLosslessImage(i->tag,mem,sizex,sizey); + } + } + + if(newpic) + free(newpic); - m.tx = (int)(p1.x*20); - m.ty = (int)(p1.y*20); + return bitid; +} + +void swf_fillbitmap(gfxdevice_t*dev, gfxline_t*line, gfximage_t*img, gfxmatrix_t*matrix, gfxcxform_t*cxform) +{ + swfoutput_internal*i = (swfoutput_internal*)dev->internal; + swfoutput*obj = i->obj; + + if(i->shapeid>=0) + endshape(obj,0); + if(i->textid>=0) + endtext(obj); + + gfxbbox_t bbox = gfxline_getbbox(line); + + int targetx = (int)(sqrt(matrix->m00*matrix->m00 + matrix->m01*matrix->m01)*img->width); + int targety = (int)(sqrt(matrix->m10*matrix->m10 + matrix->m11*matrix->m11)*img->height); + + int newwidth=0,newheight=0; + int bitid = add_image(i, img, targetx, targety, &newwidth, &newheight); + double fx = (double)img->width / (double)newwidth; + double fy = (double)img->height / (double)newheight; + + MATRIX m; + float m00,m10,tx; + float m01,m11,ty; + m.sx = (int)(65536*20*matrix->m00*fx); + m.r0 = (int)(65536*20*matrix->m01*fx); + m.r1 = (int)(65536*20*matrix->m10*fy); + m.sy = (int)(65536*20*matrix->m11*fy); + m.tx = (int)(matrix->tx*20); + m.ty = (int)(matrix->ty*20); /* shape */ - myshapeid = ++i->currentswfid; + int myshapeid = ++i->currentswfid; i->tag = swf_InsertTag(i->tag,ST_DEFINESHAPE); SHAPE*shape; swf_ShapeNew(&shape); - //lsid = ShapeAddLineStyle(shape,linewidth,&obj->strokergb); - //fsid = ShapeAddSolidFillStyle(shape,&obj->fillrgb); - fsid = swf_ShapeAddBitmapFillStyle(shape,&m,bitid,1); + int fsid = swf_ShapeAddBitmapFillStyle(shape,&m,bitid,1); + SRECT r; swf_SetU16(i->tag, myshapeid); - r.xmin = (int)(xmin*20); - r.ymin = (int)(ymin*20); - r.xmax = (int)(xmax*20); - r.ymax = (int)(ymax*20); + r.xmin = (int)(bbox.xmin*20); + r.ymin = (int)(bbox.ymin*20); + r.xmax = (int)(bbox.xmax*20); + r.ymax = (int)(bbox.ymax*20); swf_SetRect(i->tag,&r); swf_SetShapeStyles(i->tag,shape); swf_ShapeCountBits(shape,NULL,NULL); swf_SetShapeBits(i->tag,shape); - swf_ShapeSetAll(i->tag,shape,/*x*/0,/*y*/0,lsid,fsid,0); + swf_ShapeSetAll(i->tag,shape,/*x*/0,/*y*/0,/*ls*/0,fsid,0); i->swflastx = i->swflasty = 0; - moveto(obj, i->tag, p1); - lineto(obj, i->tag, p2); - lineto(obj, i->tag, p3); - lineto(obj, i->tag, p4); - lineto(obj, i->tag, p1); - /* - ShapeMoveTo (tag, shape, (int)(x1*20),(int)(y1*20)); - ShapeSetLine (tag, shape, (int)(x1*20); - ShapeSetLine (tag, shape, x*20,0); - ShapeSetLine (tag, shape, 0,-y*20); - ShapeSetLine (tag, shape, -x*20,0);*/ + drawgfxline(obj, line); swf_ShapeSetEnd(i->tag); swf_ShapeFree(shape); - /* instance */ i->tag = swf_InsertTag(i->tag,ST_PLACEOBJECT2); - - swf_ObjectPlace(i->tag,myshapeid,/*depth*/i->depth++,&i->page_matrix,NULL,NULL); + CXFORM cxform2 = gfxcxform_to_cxform(cxform); + swf_ObjectPlace(i->tag,myshapeid,/*depth*/i->depth++,&i->page_matrix,&cxform2,NULL); } -int swfoutput_drawimagejpeg_old(struct swfoutput*obj, char*filename, int sizex,int sizey, +#define IMAGE_TYPE_JPEG 0 +#define IMAGE_TYPE_LOSSLESS 1 + +static void swfoutput_drawimage(struct swfoutput*obj, RGBA* data, int sizex,int sizey, double x1,double y1, double x2,double y2, double x3,double y3, - double x4,double y4) + double x4,double y4, int type) { swfoutput_internal*i = (swfoutput_internal*)obj->internal; - TAG*oldtag; - if(i->shapeid>=0) - endshape(obj,0); - if(i->textid>=0) - endtext(obj); - int bitid = ++i->currentswfid; - oldtag = i->tag; - i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSJPEG2); - swf_SetU16(i->tag, bitid); - if(swf_SetJPEGBits(i->tag, filename, config_jpegquality)<0) { - swf_DeleteTag(i->tag); - i->tag = oldtag; - return -1; + RGBA*newpic=0; + + double l1 = sqrt((x4-x1)*(x4-x1) + (y4-y1)*(y4-y1)); + double l2 = sqrt((x2-x1)*(x2-x1) + (y2-y1)*(y2-y1)); + + gfxline_t p1,p2,p3,p4,p5; + p1.type=gfx_moveTo;p1.x=x1; p1.y=y1;p1.next=&p2; + p2.type=gfx_lineTo;p2.x=x2; p2.y=y2;p2.next=&p3; + p3.type=gfx_lineTo;p3.x=x3; p3.y=y3;p3.next=&p4; + p4.type=gfx_lineTo;p4.x=x4; p4.y=y4;p4.next=&p5; + p5.type=gfx_lineTo;p5.x=x1; p5.y=y1;p5.next=0; + + {p1.x = (int)(p1.x*20)/20.0; + p1.y = (int)(p1.y*20)/20.0; + p2.x = (int)(p2.x*20)/20.0; + p2.y = (int)(p2.y*20)/20.0; + p3.x = (int)(p3.x*20)/20.0; + p3.y = (int)(p3.y*20)/20.0; + p4.x = (int)(p4.x*20)/20.0; + p4.y = (int)(p4.y*20)/20.0; + p5.x = (int)(p5.x*20)/20.0; + p5.y = (int)(p5.y*20)/20.0; } + + float m00,m10,tx; + float m01,m11,ty; + + gfxmatrix_t m; + m.m00 = (p4.x-p1.x)/sizex; + m.m01 = (p1.x-p2.x)/sizey; + m.m10 = -(p4.y-p1.y)/sizex; + m.m11 = -(p1.y-p2.y)/sizey; + m.tx = p1.x - 0.5; + m.ty = p1.y - 0.5; + + gfximage_t img; + img.data = (gfxcolor_t*)data; + img.width = sizex; + img.height = sizey; + + if(type == IMAGE_TYPE_JPEG) + /* TODO: pass image_dpi to device instead */ + i->device.setparameter(&i->device, "next_bitmap_is_jpeg", "1"); - drawimage(obj, bitid, sizex, sizey, x1,y1,x2,y2,x3,y3,x4,y4); - return bitid; + i->device.fillbitmap(&i->device, &p1, &img, &m, 0); } -int swfoutput_drawimagejpeg(struct swfoutput*obj, RGBA*mem, int sizex,int sizey, - double x1,double y1, - double x2,double y2, - double x3,double y3, - double x4,double y4) +void swfoutput_drawimagejpeg(struct swfoutput*obj, RGBA*mem, int sizex,int sizey, + double x1,double y1, double x2,double y2, double x3,double y3, double x4,double y4) { - swfoutput_internal*i = (swfoutput_internal*)obj->internal; - TAG*oldtag; - JPEGBITS*jpeg; - - if(i->shapeid>=0) - endshape(obj,0); - if(i->textid>=0) - endtext(obj); - - int bitid = ++i->currentswfid; - oldtag = i->tag; - i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSJPEG2); - swf_SetU16(i->tag, bitid); - swf_SetJPEGBits2(i->tag,sizex,sizey,mem,config_jpegquality); - drawimage(obj, bitid, sizex, sizey, x1,y1,x2,y2,x3,y3,x4,y4); - return bitid; + swfoutput_drawimage(obj,mem,sizex,sizey,x1,y1,x2,y2,x3,y3,x4,y4, IMAGE_TYPE_JPEG); } -int swfoutput_drawimagelossless(struct swfoutput*obj, RGBA*mem, int sizex,int sizey, - double x1,double y1, - double x2,double y2, - double x3,double y3, - double x4,double y4) +void swfoutput_drawimagelossless(struct swfoutput*obj, RGBA*mem, int sizex,int sizey, + double x1,double y1, double x2,double y2, double x3,double y3, double x4,double y4) { - swfoutput_internal*i = (swfoutput_internal*)obj->internal; - TAG*oldtag; - if(i->shapeid>=0) - endshape(obj,0); - if(i->textid>=0) - endtext(obj); - - int bitid = ++i->currentswfid; - oldtag = i->tag; - i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSLOSSLESS); - swf_SetU16(i->tag, bitid); - if(swf_SetLosslessBits(i->tag,sizex,sizey,mem, BMF_32BIT)<0) { - swf_DeleteTag(i->tag); - i->tag = oldtag; - return -1; - } - - drawimage(obj, bitid, sizex, sizey, x1,y1,x2,y2,x3,y3,x4,y4); - return bitid; + swfoutput_drawimage(obj,mem,sizex,sizey,x1,y1,x2,y2,x3,y3,x4,y4, IMAGE_TYPE_LOSSLESS); } -int swfoutput_drawimagelosslessN(struct swfoutput*obj, U8*mem, RGBA*pal, int sizex,int sizey, - double x1,double y1, - double x2,double y2, - double x3,double y3, - double x4,double y4, int n) +int swf_setparameter(gfxdevice_t*dev, const char*key, const char*value) { - swfoutput_internal*i = (swfoutput_internal*)obj->internal; - TAG*oldtag; - U8*mem2 = 0; - if(i->shapeid>=0) - endshape(obj,0); - if(i->textid>=0) - endtext(obj); - - if(sizex&3) - { - /* SWF expects scanlines to be 4 byte aligned */ - int x,y; - U8*ptr; - mem2 = (U8*)malloc(BYTES_PER_SCANLINE(sizex)*sizey); - ptr = mem2; - for(y=0;yinternal)->jpeg = 1; + return 1; } - - int bitid = ++i->currentswfid; - oldtag = i->tag; - i->tag = swf_InsertTag(i->tag,ST_DEFINEBITSLOSSLESS2); - swf_SetU16(i->tag, bitid); - if(swf_SetLosslessBitsIndexed(i->tag,sizex,sizey,mem, pal, n)<0) { - swf_DeleteTag(i->tag); - i->tag = oldtag; - return -1; - } - if(mem2) - free(mem2); - - drawimage(obj, bitid, sizex, sizey, x1,y1,x2,y2,x3,y3,x4,y4); - return bitid; -} - -void swfoutput_drawimageagain(struct swfoutput*obj, int id, int sizex,int sizey, - double x1,double y1, - double x2,double y2, - double x3,double y3, - double x4,double y4) -{ - swfoutput_internal*i = (swfoutput_internal*)obj->internal; - if(id<0) return; - if(i->shapeid>=0) - endshape(obj,0); - if(i->textid>=0) - endtext(obj); - - drawimage(obj, id, sizex, sizey, x1,y1,x2,y2,x3,y3,x4,y4); + return 0; } void swfoutput_setparameter(char*name, char*value) { - if(!strcmp(name, "drawonlyshapes")) { + if(!strcmp(name, "jpegsubpixels")) { + config_jpegsubpixels = atof(value); + } else if(!strcmp(name, "ppmsubpixels")) { + config_ppmsubpixels = atof(value); + } else if(!strcmp(name, "drawonlyshapes")) { config_drawonlyshapes = atoi(value); } else if(!strcmp(name, "ignoredraworder")) { config_ignoredraworder = atoi(value);