X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=pdf2swf%2Fswfoutput.cc;h=1ac10c8c0af5836c171972ecbc4c2efc07283876;hb=a1479904a4fa6a6b572e10e7d137249ad8938007;hp=5921251507c04b7db19b8f01f78e43ef7d6e3261;hpb=805f5355196fae7072f303c8d88cee1c851834ab;p=swftools.git diff --git a/pdf2swf/swfoutput.cc b/pdf2swf/swfoutput.cc index 5921251..1ac10c8 100644 --- a/pdf2swf/swfoutput.cc +++ b/pdf2swf/swfoutput.cc @@ -71,13 +71,13 @@ int clippos = 0; int CHARMIDX = 0; int CHARMIDY = 0; -void startshape(struct swfoutput* obj); -void starttext(struct swfoutput* obj); -void endshape(); -void endtext(); +static void startshape(struct swfoutput* obj); +static void starttext(struct swfoutput* obj); +static void endshape(); +static void endtext(); // matrix multiplication. changes p0 -void transform (plotxy*p0,struct swfmatrix*m) +static void transform (plotxy*p0,struct swfmatrix*m) { double x,y; x = m->m11*p0->x+m->m12*p0->y; @@ -87,7 +87,7 @@ void transform (plotxy*p0,struct swfmatrix*m) } // write a move-to command into the swf -void moveto(TAG*tag, plotxy p0) +static void moveto(TAG*tag, plotxy p0) { int rx = (int)(p0.x*20); int ry = (int)(p0.y*20); @@ -99,7 +99,7 @@ void moveto(TAG*tag, plotxy p0) } // write a line-to command into the swf -void lineto(TAG*tag, plotxy p0) +static void lineto(TAG*tag, plotxy p0) { int rx = ((int)(p0.x*20)-swflastx); int ry = ((int)(p0.y*20)-swflasty); @@ -111,7 +111,7 @@ void lineto(TAG*tag, plotxy p0) } // write a spline-to command into the swf -void splineto(TAG*tag, plotxy control,plotxy end) +static void splineto(TAG*tag, plotxy control,plotxy end) { int cx = ((int)(control.x*20)-swflastx); int cy = ((int)(control.y*20)-swflasty); @@ -121,12 +121,13 @@ void splineto(TAG*tag, plotxy control,plotxy end) int ey = ((int)(end.y*20)-swflasty); swflastx += ex; swflasty += ey; - swf_ShapeSetCurve(tag, shape, cx,cy,ex,ey); + if(cx || cy || ex || ey) + swf_ShapeSetCurve(tag, shape, cx,cy,ex,ey); } /* write a line, given two points and the transformation matrix. */ -void line(TAG*tag, plotxy p0, plotxy p1, struct swfmatrix*m) +static void line(TAG*tag, plotxy p0, plotxy p1, struct swfmatrix*m) { transform(&p0,m); transform(&p1,m); @@ -136,7 +137,7 @@ void line(TAG*tag, plotxy p0, plotxy p1, struct swfmatrix*m) /* write a cubic (!) spline. This involves calling the approximate() function out of spline.cc to convert it to a quadratic spline. */ -void spline(TAG*tag,plotxy p0,plotxy p1,plotxy p2,plotxy p3,struct swfmatrix*m) +static void spline(TAG*tag,plotxy p0,plotxy p1,plotxy p2,plotxy p3,struct swfmatrix*m) { double d; struct qspline q[16]; @@ -251,7 +252,7 @@ void drawpath(TAG*tag, T1_OUTLINE*outline, struct swfmatrix*m, int log) } } -int colorcompare(RGBA*a,RGBA*b) +static inline int colorcompare(RGBA*a,RGBA*b) { if(a->r!=b->r || @@ -274,7 +275,7 @@ struct chardata { } chardata[CHARDATAMAX]; int chardatapos = 0; -void putcharacters(TAG*tag) +static void putcharacters(TAG*tag) { int t; SWFFONT font; @@ -406,7 +407,7 @@ void putcharacters(TAG*tag) chardatapos = 0; } -void putcharacter(struct swfoutput*obj, int fontid, int charid, +static void putcharacter(struct swfoutput*obj, int fontid, int charid, int x,int y, int size) { if(chardatapos == CHARDATAMAX) @@ -425,7 +426,7 @@ void putcharacter(struct swfoutput*obj, int fontid, int charid, /* process a character. */ -void drawchar(struct swfoutput*obj, SWFFont*font, char*character, int charnr, swfmatrix*m) +static void drawchar(struct swfoutput*obj, SWFFont*font, char*character, int charnr, swfmatrix*m) { int usefonts=1; if(m->m12!=0 || m->m21!=0) @@ -450,7 +451,7 @@ void drawchar(struct swfoutput*obj, SWFFont*font, char*character, int charnr, sw if(!outline) { logf(" Didn't find %s in current charset (%s)", - character,font->getName()); + FIXNULL(character),FIXNULL(font->getName())); return; } @@ -521,7 +522,7 @@ SWFFont::SWFFont(char*name, int id, char*filename) if(!charnum) return; - logf(" Font %s(%d): Storing %d outlines.\n", name, id, charnum); + logf(" Font %s(%d): Storing %d outlines.\n", FIXNULL(name), id, charnum); this->standardtablesize = 256; if(this->charnum < this->standardtablesize) @@ -607,7 +608,7 @@ SWFFont::~SWFFont() if(usednum && !drawonlyshapes) { - logf(" Font %s has %d used characters",fontid, usednum); + logf(" Font %s has %d used characters",FIXNULL(fontid), usednum); TAG*ftag = swf_InsertTag(swf.firstTag,ST_DEFINEFONT); swf_SetU16(ftag, this->swfid); int initpos = swf_GetTagLen(ftag); @@ -624,7 +625,9 @@ SWFFont::~SWFFont() } for(t=0;tdata[ptr[t]] = swf_GetTagLen(ftag)-initpos; + *(U16*)&ftag->data[ptr[t]] = + SWAP16(swf_GetTagLen(ftag)-initpos); + swflastx=0; swflasty=0; swf_SetU8(ftag,0x10); //0 fill bits, 0 linestyle bits @@ -724,7 +727,7 @@ int SWFFont::getSWFCharID(char*name, int charnr) if(this->standardtable && charnr>=0 && charnr < this->standardtablesize) { return getSWFCharID(this->standardtable[charnr], -1); } - logf(" Didn't find character '%s' in font '%s'", name, this->name); + logf(" Didn't find character '%s' in font '%s'", FIXNULL(name), this->name); return 0; } @@ -760,7 +763,7 @@ void swfoutput_setfont(struct swfoutput*obj, char*fontid, int t1id, char*filenam } if(t1id<0) { - logf(" internal error: t1id:%d, fontid:%s\n", t1id,fontid); + logf(" internal error: t1id:%d, fontid:%s\n", t1id,FIXNULL(fontid)); } SWFFont*font = new SWFFont(fontid, t1id, filename); @@ -856,7 +859,7 @@ void swfoutput_setprotected() //write PROTECT tag flag_protected = 1; } -void startshape(struct swfoutput*obj) +static void startshape(struct swfoutput*obj) { RGBA rgb; SRECT r; @@ -892,7 +895,7 @@ void startshape(struct swfoutput*obj) lastwasfill = 0; } -void starttext(struct swfoutput*obj) +static void starttext(struct swfoutput*obj) { SRECT r; MATRIX m; @@ -920,7 +923,7 @@ void starttext(struct swfoutput*obj) swflastx=swflasty=0; } -void endshape() +static void endshape() { if(shapeid<0) return; @@ -930,7 +933,7 @@ void endshape() shapeid = -1; } -void endtext() +static void endtext() { if(textid<0) return; @@ -941,7 +944,7 @@ void endtext() textid = -1; } -void endpage(struct swfoutput*obj) +static void endpage(struct swfoutput*obj) { if(shapeid>=0) endshape(); @@ -988,7 +991,7 @@ void swfoutput_destroy(struct swfoutput* obj) fi = 1; // stdout if(fi<=0) { - logf(" Could not create \"%s\". ", filename); + logf(" Could not create \"%s\". ", FIXNULL(filename)); exit(1); } @@ -1100,7 +1103,7 @@ void swfoutput_endclip(swfoutput*obj) swf_ObjectPlaceClip(cliptags[clippos],clipshapes[clippos],clipdepths[clippos],NULL,NULL,NULL,depth++); } -void drawlink(struct swfoutput*obj, ActionTAG*, swfcoord*points); +static void drawlink(struct swfoutput*obj, ActionTAG*,ActionTAG*, swfcoord*points, char mouseover); void swfoutput_linktourl(struct swfoutput*obj, char*url, swfcoord*points) { @@ -1119,7 +1122,7 @@ void swfoutput_linktourl(struct swfoutput*obj, char*url, swfcoord*points) action_End(); swf_ActionEnd(); - drawlink(obj, actions, points); + drawlink(obj, actions, 0, points,0); } void swfoutput_linktopage(struct swfoutput*obj, int page, swfcoord*points) { @@ -1135,10 +1138,38 @@ void swfoutput_linktopage(struct swfoutput*obj, int page, swfcoord*points) action_End(); swf_ActionEnd(); - drawlink(obj, actions, points); + drawlink(obj, actions, 0, points,0); } +void swfoutput_namedlink(struct swfoutput*obj, char*name, swfcoord*points) +{ + ActionTAG *actions1,*actions2; + + if(shapeid>=0) + endshape(); + if(textid>=0) + endtext(); + + actions1 = swf_ActionStart(); + action_PushString("/:subtitle"); + action_PushString(name); + action_SetVariable(); + action_End(); + swf_ActionEnd(); + + actions2 = swf_ActionStart(); + action_PushString("/:subtitle"); + action_PushString(""); + action_SetVariable(); + action_End(); + swf_ActionEnd(); -void drawlink(struct swfoutput*obj, ActionTAG*actions, swfcoord*points) + drawlink(obj, actions1, actions2, points,1); + + swf_ActionFree(actions1); + swf_ActionFree(actions2); +} + +static void drawlink(struct swfoutput*obj, ActionTAG*actions1, ActionTAG*actions2, swfcoord*points, char mouseover) { RGBA rgb; SRECT r; @@ -1210,22 +1241,47 @@ void drawlink(struct swfoutput*obj, ActionTAG*actions, swfcoord*points) lineto(tag, p1); swf_ShapeSetEnd(tag); - tag = swf_InsertTag(tag,ST_DEFINEBUTTON); - swf_SetU16(tag,buttonid); //id - swf_ButtonSetFlags(tag, 0); //menu=no - swf_ButtonSetRecord(tag,0x01,myshapeid,depth,0,0); - swf_ButtonSetRecord(tag,0x02,myshapeid2,depth,0,0); - swf_ButtonSetRecord(tag,0x04,myshapeid2,depth,0,0); - swf_ButtonSetRecord(tag,0x08,myshapeid,depth,0,0); - swf_SetU8(tag,0); - swf_ActionSet(tag,actions); - swf_SetU8(tag,0); + if(!mouseover) + { + tag = swf_InsertTag(tag,ST_DEFINEBUTTON); + swf_SetU16(tag,buttonid); //id + swf_ButtonSetFlags(tag, 0); //menu=no + swf_ButtonSetRecord(tag,0x01,myshapeid,depth,0,0); + swf_ButtonSetRecord(tag,0x02,myshapeid2,depth,0,0); + swf_ButtonSetRecord(tag,0x04,myshapeid2,depth,0,0); + swf_ButtonSetRecord(tag,0x08,myshapeid,depth,0,0); + swf_SetU8(tag,0); + swf_ActionSet(tag,actions1); + swf_SetU8(tag,0); + } + else + { + tag = swf_InsertTag(tag,ST_DEFINEBUTTON2); + swf_SetU16(tag,buttonid); //id + swf_ButtonSetFlags(tag, 0); //menu=no + swf_ButtonSetRecord(tag,0x01,myshapeid,depth,0,0); + swf_ButtonSetRecord(tag,0x02,myshapeid2,depth,0,0); + swf_ButtonSetRecord(tag,0x04,myshapeid2,depth,0,0); + swf_ButtonSetRecord(tag,0x08,myshapeid,depth,0,0); + swf_SetU8(tag,0); // end of button records + swf_ButtonSetCondition(tag, BC_IDLE_OVERUP); + swf_ActionSet(tag,actions1); + if(actions2) { + swf_ButtonSetCondition(tag, BC_OVERUP_IDLE); + swf_ActionSet(tag,actions2); + swf_SetU8(tag,0); + swf_ButtonPostProcess(tag, 2); + } else { + swf_SetU8(tag,0); + swf_ButtonPostProcess(tag, 1); + } + } tag = swf_InsertTag(tag,ST_PLACEOBJECT2); swf_ObjectPlace(tag, buttonid, depth++,0,0,0); } -void drawimage(struct swfoutput*obj, int bitid, int sizex,int sizey, +static void drawimage(struct swfoutput*obj, int bitid, int sizex,int sizey, double x1,double y1, double x2,double y2, double x3,double y3,