new tags are now mapped to their own IDs, not an allocated one
[swftools.git] / lib / rfxswf.h
1 /* rfxswf.h
2
3    Headers for rfxswf.c and modules
4
5    Part of the swftools package.
6
7    Copyright (c) 2000, 2001 Rainer Böhme <rfxswf@reflex-studio.de>
8  
9    This program is free software; you can redistribute it and/or modify
10    it under the terms of the GNU General Public License as published by
11    the Free Software Foundation; either version 2 of the License, or
12    (at your option) any later version.
13
14    This program is distributed in the hope that it will be useful,
15    but WITHOUT ANY WARRANTY; without even the implied warranty of
16    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17    GNU General Public License for more details.
18
19    You should have received a copy of the GNU General Public License
20    along with this program; if not, write to the Free Software
21    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA */
22  
23
24 #ifndef __RFX_SWF_INCLUDED__
25 #define __RFX_SWF_INCLUDED__
26
27 #ifdef __cplusplus
28 extern "C" {
29 #endif
30
31 #include <stdio.h>
32 #include <stdlib.h>
33 #include <string.h>
34 #include <unistd.h>
35 #include <fcntl.h>
36 #include <ctype.h>
37 #include "../config.h"
38 #include "./bitio.h"
39 #include "./drawer.h"
40
41 #define DEBUG_RFXSWF
42 #ifdef RFXSWF_DISABLESOUND
43 #define NO_MP3
44 #endif
45
46 #ifndef TRUE
47 #define TRUE (1)
48 #endif
49 #ifndef FALSE
50 #define FALSE (0)
51 #endif
52
53
54 /* little/big endian stuff */
55
56 #define PUT8(ptr,x) {((U8*)(ptr))[0]=x;}
57 #define PUT16(ptr,x) {((U8*)(ptr))[0]=(U8)(x);((U8*)(ptr))[1]=(U8)((x)>>8);}
58 #define PUT32(ptr,x) {((U8*)(ptr))[0]=(U8)(x);((U8*)(ptr))[1]=(U8)((x)>>8);((U8*)(ptr))[2]=(U8)((x)>>16);((U8*)(ptr))[3]=(U8)((x)>>24);}
59 #define GET16(ptr) (((U16)(((U8*)(ptr))[0]))+(((U16)(((U8*)(ptr))[1]))<<8))
60 #define GET32(ptr) (((U16)(((U8*)(ptr))[0]))+(((U16)(((U8*)(ptr))[1]))<<8)+(((U16)(((U8*)(ptr))[2]))<<16)+(((U16)(((U8*)(ptr))[3]))<<24))
61
62 #ifdef WORDS_BIGENDIAN
63 #define SWAP16(s) ((((s)>>8)&0x00ff)|(((s)<<8)&0xff00))
64 #define SWAP32(s) (SWAP16(((s)>>16)&0x0000ffff)|((SWAP16(s)<<16)&0xffff0000))
65 #define REVERSESWAP16(x) (x)
66 #define REVERSESWAP32(x) (x)
67 #else
68 #define SWAP16(x) (x)
69 #define SWAP32(x) (x)
70 #define REVERSESWAP16(s) ((((s)>>8)&0x00ff)|(((s)<<8)&0xff00))
71 #define REVERSESWAP32(s) (REVERSESWAP16(((s)>>16)&0x0000ffff)|((REVERSESWAP16(s)<<16)&0xffff0000))
72 #endif
73 // SWF Types
74
75 typedef         unsigned long   U32;
76 typedef         signed long     S32;
77 typedef         unsigned short  U16;
78 typedef         signed short    S16;
79 typedef         unsigned char   U8;
80 typedef         signed char     S8;
81 typedef         signed long     SFIXED;
82 typedef         signed long     SCOORD;
83
84 #define SCOORD_MAX 0x7fffffff
85 #define SCOORD_MIN -0x80000000
86
87 // Basic Structures
88
89 typedef struct _SPOINT
90 { SCOORD        x;
91   SCOORD        y;
92 } SPOINT, * LPSPOINT;
93
94 typedef struct _RGBA
95 { U8    a;
96   U8    r;
97   U8    g;
98   U8    b;
99 } RGBA, * LPRGBA;
100
101 typedef struct _YUV
102 {
103   U8    y,u,v;
104 } YUV;
105
106 typedef struct _SRECT
107 { SCOORD        xmin;
108   SCOORD        ymin;
109   SCOORD        xmax;
110   SCOORD        ymax;
111 } SRECT, * LPSRECT;
112
113 typedef struct _MATRIX
114 { SFIXED        sx;     // factor x
115   SFIXED        sy;
116   SFIXED        r0;     // rotation
117   SFIXED        r1;
118   SCOORD        tx;     // delta x
119   SCOORD        ty;
120 } MATRIX, * LPMATRIX;
121
122 typedef struct _CXFORM
123 { S16           a0, a1; /* mult, add */
124   S16           r0, r1;
125   S16           g0, g1;
126   S16           b0, b1;
127 } CXFORM, * LPCXFORM;
128
129 #define GRADIENT_LINEAR 0x10
130 #define GRADIENT_RADIAL 0x12
131 typedef struct _GRADIENT
132 {
133     int num;
134     U8 ratios[8];
135     RGBA rgba[8];
136 } GRADIENT;
137
138 typedef struct _TAG             // NEVER access a Tag-Struct directly !
139 { U16           id;
140   U8 *          data;
141   U32           memsize;        // to minimize realloc() calls
142
143   U32         len;            // for Set-Access
144   U32         pos;            // for Get-Access
145
146   struct _TAG * next;
147   struct _TAG * prev;
148
149   U8            readBit;        // for Bit-Manipulating Functions [read]
150   U8            writeBit;       // [write]
151   
152 } TAG, * LPTAG;
153
154 typedef struct _SOUNDINFO 
155 {
156     U8 stop;
157     U8 nomultiple; //continue playing if already started
158
159     U32 inpoint;
160     U32 outpoint;
161
162     U16 loops;
163     U8 envelopes;
164
165     //envelope:
166     U32* pos;
167     U32* left;
168     U32* right;
169 } SOUNDINFO;
170
171 typedef struct _SWF
172 { U8            fileVersion;
173   U8            compressed;     // SWF or SWC?
174   U32           fileSize;       // valid after load and save
175   SRECT         movieSize;
176   U16           frameRate;
177   U16           frameCount;     // valid after load and save
178   TAG *         firstTag;
179 } SWF, * LPSWF;
180
181 // Basic Functions
182
183 int  swf_ReadSWF2(struct reader_t*reader, SWF * swf);   // Reads SWF via callback
184 int  swf_ReadSWF(int handle,SWF * swf);     // Reads SWF to memory (malloc'ed), returns length or <0 if fails
185 int  swf_WriteSWF2(struct writer_t*writer, SWF * swf);     // Writes SWF via callback, returns length or <0 if fails
186 int  swf_WriteSWF(int handle,SWF * swf);    // Writes SWF to file, returns length or <0 if fails
187 int  swf_WriteSWC(int handle, SWF * swf);   // for convenience, equal to swf->compressed=1;swf_WriteSWF(..)
188 int  swf_WriteCGI(SWF * swf);               // Outputs SWF with valid CGI header to stdout
189 void swf_FreeTags(SWF * swf);               // Frees all malloc'ed memory for swf
190
191 // for streaming:
192 int  swf_WriteHeader(int handle,SWF * swf);    // Writes Header of swf to file
193 int  swf_WriteHeader2(struct writer_t*writer,SWF * swf);    // Writes Header of swf to file
194 int  swf_WriteTag(int handle,TAG * tag);    // Writes TAG to file
195 int  swf_WriteTag2(struct writer_t*writer, TAG * t); //Write TAG via callback
196
197 int  swf_ReadHeader(struct reader_t*reader, SWF * swf);   // Reads SWF Header via callback
198
199 // folding/unfolding:
200
201 void swf_FoldAll(SWF*swf);
202 void swf_UnFoldAll(SWF*swf);
203 void swf_FoldSprite(TAG*tag);
204 void swf_UnFoldSprite(TAG*tag);
205 int swf_IsFolded(TAG*tag);
206
207 // tag reordering:
208
209 void swf_OptimizeTagOrder(SWF*swf);
210
211 // basic routines:
212     
213 TAG * swf_InsertTag(TAG * after,U16 id);    // updates frames, if necessary
214 TAG * swf_InsertTagBefore(SWF*swf, TAG * before,U16 id);     // like InsertTag, but insert tag before argument
215 int   swf_DeleteTag(TAG * t);
216
217 void  swf_ClearTag(TAG * t);                //frees tag data
218 void  swf_ResetTag(TAG*tag, U16 id);        //set's tag position and length to 0, without freeing it
219     
220 void  swf_SetTagPos(TAG * t,U32 pos);       // resets Bitcount
221 U32   swf_GetTagPos(TAG * t);
222
223 TAG * swf_NextTag(TAG * t);
224 TAG * swf_PrevTag(TAG * t);
225
226 U16   swf_GetTagID(TAG * t);                // ... TagGetID
227 U32   swf_GetTagLen(TAG * t);             // ... TagGetTagLen
228 U8*   swf_GetTagLenPtr(TAG * t);
229
230 U32   swf_GetBits(TAG * t,int nbits);
231 S32   swf_GetSBits(TAG * t,int nbits);
232 int   swf_SetBits(TAG * t,U32 v,int nbits);
233
234 int   swf_GetBlock(TAG * t,U8 * b,int l);   // resets Bitcount
235 int   swf_SetBlock(TAG * t,U8 * b,int l);
236
237 U8    swf_GetU8(TAG * t);                   // resets Bitcount
238 U16   swf_GetU16(TAG * t);
239 U32   swf_GetU32(TAG * t);
240 void  swf_GetRGB(TAG * t, RGBA * col);
241 void  swf_GetRGBA(TAG * t, RGBA * col);
242 void  swf_GetGradient(TAG * t, GRADIENT * gradient, char alpha);
243 char* swf_GetString(TAG*t);
244 int   swf_SetU8(TAG * t,U8 v);              // resets Bitcount
245 int   swf_SetU16(TAG * t,U16 v);
246 int   swf_SetU32(TAG * t,U32 v);
247
248 //int   swf_GetPoint(TAG * t,SPOINT * p);     // resets Bitcount
249 int   swf_GetRect(TAG * t,SRECT * r);
250 int   swf_GetMatrix(TAG * t,MATRIX * m);
251 int   swf_GetCXForm(TAG * t,CXFORM * cx,U8 alpha);
252
253 //int   swf_SetPoint(TAG * t,SPOINT * p);     // resets Bitcount
254 int   swf_SetRect(TAG * t,SRECT * r);
255 int   swf_SetMatrix(TAG * t,MATRIX * m);
256 int   swf_SetCXForm(TAG * t,CXFORM * cx,U8 alpha);
257 int   swf_SetRGB(TAG * t,RGBA * col);
258 int   swf_SetRGBA(TAG * t,RGBA * col);
259 void  swf_SetPassword(TAG * t, const char * password);
260
261 int   swf_VerifyPassword(TAG * t, const char * password);
262
263 // helper functions:
264
265 void swf_ExpandRect(SRECT*src, SPOINT add);
266 void swf_ExpandRect2(SRECT*src, SRECT*add);
267 SPOINT swf_TurnPoint(SPOINT p, MATRIX* m);
268 SRECT swf_TurnRect(SRECT r, MATRIX* m);
269
270 // Function Macros
271
272 #define swf_GetS8(tag)      ((S8)swf_GetU8(tag))
273 #define swf_GetS16(tag)     ((S16)swf_GetU16(tag))
274 #define swf_GetS32(tag)     ((S32)swf_GetU32(tag))
275 #define swf_GetCoord(tag)   ((SCOORD)swf_GetU32(tag))
276 #define swf_GetFixed(tag)   ((SFIXED)swf_GetU32(tag))
277
278 #define swf_SetS8(tag,v)    swf_SetU8(tag,(U8)v)
279 #define swf_SetS16(tag,v)   swf_SetU16(tag,(U16)v)
280 #define swf_SetS32(tag,v)   swf_SetU32(tag,(U32)v)
281 #define swf_SetCoord(tag,v) swf_SetU32(tag,(U32)v)
282 #define swf_SetFixed(tag,v) swf_SetU32(tag,(U32)v)
283 #define swf_SetString(t,s)  swf_SetBlock(t,s,strlen(s)+1)
284
285 #ifndef FAILED
286 #define FAILED(b)       ((b)<0)
287 #endif
288 #ifndef SUCCEEDED
289 #define SUCCEEDED(b)     ((b)>=0)
290 #endif
291
292 // Tag IDs (adopted from J. C. Kessels' Form2Flash)
293
294 #define ST_END                  0
295 #define ST_SHOWFRAME            1
296 #define ST_DEFINESHAPE          2
297 #define ST_FREECHARACTER        3
298 #define ST_PLACEOBJECT          4
299 #define ST_REMOVEOBJECT         5
300 #define ST_DEFINEBITS           6
301 #define ST_DEFINEBITSJPEG       6 
302 #define ST_DEFINEBUTTON         7
303 #define ST_JPEGTABLES           8
304 #define ST_SETBACKGROUNDCOLOR   9
305 #define ST_DEFINEFONT           10
306 #define ST_DEFINETEXT           11
307 #define ST_DOACTION             12
308 #define ST_DEFINEFONTINFO       13
309 #define ST_DEFINESOUND          14 /* Event sound tags. */
310 #define ST_STARTSOUND           15
311 #define ST_DEFINEBUTTONSOUND    17
312 #define ST_SOUNDSTREAMHEAD      18
313 #define ST_SOUNDSTREAMBLOCK     19
314 #define ST_DEFINEBITSLOSSLESS   20 /* A bitmap using lossless zlib compression. */
315 #define ST_DEFINEBITSJPEG2      21 /* A bitmap using an internal JPEG compression table. */
316 #define ST_DEFINESHAPE2         22
317 #define ST_DEFINEBUTTONCXFORM   23
318 #define ST_PROTECT              24 /* This file should not be importable for editing. */
319 #define ST_PLACEOBJECT2         26 /* The new style place w/ alpha color transform and name. */
320 #define ST_REMOVEOBJECT2        28 /* A more compact remove object that omits the character tag (just depth). */
321 #define ST_FREEALL              31 /* ? */
322 #define ST_DEFINESHAPE3         32 /* A shape V3 includes alpha values. */
323 #define ST_DEFINETEXT2          33 /* A text V2 includes alpha values. */
324 #define ST_DEFINEBUTTON2        34 /* A button V2 includes color transform, alpha and multiple actions */
325 #define ST_DEFINEBITSJPEG3      35 /* A JPEG bitmap with alpha info. */
326 #define ST_DEFINEBITSLOSSLESS2  36 /* A lossless bitmap with alpha info. */
327 #define ST_DEFINEEDITTEXT       37
328 #define ST_DEFINEMOVIE          38
329 #define ST_DEFINESPRITE         39 /* Define a sequence of tags that describe the behavior of a sprite. */
330 #define ST_NAMECHARACTER        40 /* Name a character definition, character id and a string, (used for buttons, bitmaps, sprites and sounds). */
331 #define ST_SERIALNUMBER         41
332 #define ST_GENERATORTEXT        42 /* contains an id */
333 #define ST_FRAMELABEL           43 /* A string label for the current frame. */
334 #define ST_SOUNDSTREAMHEAD2     45 /* For lossless streaming sound, should not have needed this... */
335 #define ST_DEFINEMORPHSHAPE     46 /* A morph shape definition */
336 #define ST_DEFINEFONT2          48
337 #define ST_TEMPLATECOMMAND      49
338 #define ST_GENERATOR3           51
339 #define ST_EXTERNALFONT         52
340 #define ST_EXPORTASSETS         56
341 #define ST_IMPORTASSETS         57
342 #define ST_ENABLEDEBUGGER       58
343 #define ST_DOINITACTION         59
344 #define ST_DEFINEVIDEOSTREAM    60
345 #define ST_VIDEOFRAME           61
346 #define ST_DEFINEFONTINFO2      62
347 #define ST_MX4                  63 /*(?) */
348 #define ST_SCRIPTLIMITS         65 /* version 7- u16 maxrecursedepth, u16 scripttimeoutseconds */
349 #define ST_SETTABINDEX          66 /* version 7- u16 depth(!), u16 tab order value */
350
351 /* custom tags- only valid for swftools */
352 #define ST_REFLEX              777 /* to identify generator software */
353 #define ST_GLYPHNAMES          778
354
355 // Advanced Funtions
356
357 // swfshape.c
358
359 typedef struct _LINESTYLE
360 { U16           width;
361   RGBA          color;
362 } LINESTYLE, * LPLINESTYLE;
363
364 typedef struct _FILLSTYLE
365 { U8        type;
366   RGBA      color;
367   MATRIX    m; 
368   U16       id_bitmap;
369   GRADIENT  gradient;
370 } FILLSTYLE, * LPFILLSTYLE;
371      
372 typedef struct _SHAPE           // NEVER access a Shape-Struct directly !
373 {                 
374   struct
375   { LINESTYLE * data;
376     U16         n;
377   } linestyle;
378                   
379   struct                    
380   { FILLSTYLE * data;
381     U16         n;
382   } fillstyle;
383  
384   struct
385   { U16         fill;
386     U16         line;
387   } bits;
388                                 // used by Get/SetSimpleShape and glyph handling
389   U8 *          data;
390   U32           bitlen;         // length of data in bits
391 } SHAPE, * LPSHAPE;
392
393 /* SHAPE can be converted into SHAPE2: */
394
395 struct _SHAPELINE;
396 typedef struct _SHAPE2
397 {
398     LINESTYLE * linestyles;
399     int numlinestyles;
400     FILLSTYLE* fillstyles;
401     int numfillstyles;
402     struct _SHAPELINE * lines;
403     SRECT* bbox; // may be NULL
404 } SHAPE2;
405
406 typedef struct _SHAPELINE
407 {
408     enum {moveTo, lineTo, splineTo} type;
409     SCOORD x,y;
410     SCOORD sx,sy; //only if type==splineTo
411     int fillstyle0;
412     int fillstyle1;
413     int linestyle;
414     struct _SHAPELINE * next;
415 } SHAPELINE;
416
417 // Shapes
418
419 int   swf_ShapeNew(SHAPE ** s);
420 void  swf_ShapeFree(SHAPE * s);
421
422 int   swf_GetSimpleShape(TAG * t,SHAPE ** s); // without Linestyle/Fillstyle Record
423 int   swf_SetSimpleShape(TAG * t,SHAPE * s);   // without Linestyle/Fillstyle Record
424
425 int   swf_ShapeAddLineStyle(SHAPE * s,U16 width,RGBA * color);
426 int   swf_ShapeAddSolidFillStyle(SHAPE * s,RGBA * color);
427 int   swf_ShapeAddBitmapFillStyle(SHAPE * s,MATRIX * m,U16 id_bitmap,int clip);
428 int   swf_ShapeAddGradientFillStyle(SHAPE * s,MATRIX * m,GRADIENT* gradient,int radial);
429
430 int   swf_SetShapeStyles(TAG * t,SHAPE * s);
431 int   swf_ShapeCountBits(SHAPE * s,U8 * fbits,U8 * lbits);
432 int   swf_SetShapeBits(TAG * t,SHAPE * s);
433 int   swf_SetShapeHeader(TAG * t,SHAPE * s); // one call for upper three functions
434
435 int   swf_ShapeSetMove(TAG * t,SHAPE * s,S32 x,S32 y);
436 int   swf_ShapeSetStyle(TAG * t,SHAPE * s,int line,int fill0,int fill1);
437 int   swf_ShapeSetAll(TAG * t,SHAPE * s,S32 x,S32 y,int line,int fill0,int fill1);
438
439 int   swf_ShapeSetLine(TAG * t,SHAPE * s,S32 x,S32 y);
440 int   swf_ShapeSetCurve(TAG * t,SHAPE * s,S32 x,S32 y,S32 ax,S32 ay);
441 int   swf_ShapeSetCircle(TAG * t,SHAPE * s,S32 x,S32 y,S32 rx,S32 ry);
442 int   swf_ShapeSetEnd(TAG * t);
443
444 void  swf_ShapeSetBitmapRect(TAG * t, U16 gfxid, int width, int height);
445
446 SHAPELINE* swf_ParseShapeData(U8*data, int bits, int fillbits, int linebits);
447 SHAPE2*    swf_ShapeToShape2(SHAPE*shape);
448 void       swf_Shape2ToShape(SHAPE2*shape2, SHAPE*shape);
449 SRECT      swf_GetShapeBoundingBox(SHAPE2*shape);
450 void        swf_SetShape2(TAG*tag, SHAPE2*shape);
451 void       swf_Shape2Free(SHAPE2 * s);
452 void    swf_DumpShape(SHAPE2*shape2);
453
454 // swfdraw.c
455
456 void swf_Shape01DrawerInit(drawer_t*draw, TAG*tag);
457 void swf_Shape11DrawerInit(drawer_t*draw, TAG*tag);
458 SHAPE* swf_ShapeDrawerToShape(drawer_t*draw);
459 SRECT swf_ShapeDrawerGetBBox(drawer_t*draw);
460
461 void swf_DrawString(drawer_t*draw, const char*source);
462
463 // swftext.c
464
465 typedef struct _KERNING
466 {
467   U16         char1;
468   U16         char2;
469   U16         adjustment;
470 } SWFKERNING;
471
472 typedef struct _SWFLAYOUT
473 { S16          ascent;
474   S16          descent;
475   S16          leading;
476   SRECT      * bounds;
477   U16          kerningcount;
478   SWFKERNING * kerning;
479 } SWFLAYOUT, * LPSWFLAYOUT;
480
481 typedef struct
482 { S16         advance;
483   SHAPE *     shape;
484 } SWFGLYPH;
485
486 #define FONT_STYLE_BOLD 1
487 #define FONT_STYLE_ITALIC 2
488 #define FONT_ENCODING_UNICODE 1
489 #define FONT_ENCODING_ANSI 2 
490 #define FONT_ENCODING_SHIFTJIS 4
491
492 typedef struct _SWFFONT
493 { int           id; // -1 = not set
494   U8            version; // 0 = not set, 1 = definefont, 2 = definefont2
495   U8 *          name;
496   SWFLAYOUT *   layout;
497   U16           numchars;
498   U16           maxascii; // highest mapped ascii value
499   
500   U8            style;
501   U8            encoding;
502
503   U16   *       glyph2ascii;
504   int   *       ascii2glyph;
505   SWFGLYPH *    glyph;
506   U8            language;
507   char **       glyphnames;
508 } SWFFONT, * LPSWFFONT;
509
510 // does not support wide characters !
511 typedef struct _FONTUSAGE
512 { U8* code;
513 } FONTUSAGE, * LPFONTUSAGE;
514
515 #define ET_HASTEXT 32768
516 #define ET_WORDWRAP 16384
517 #define ET_MULTILINE 8192
518 #define ET_PASSWORD 4096
519 #define ET_READONLY 2048
520 #define ET_HASTEXTCOLOR 1024
521 #define ET_HASMAXLENGTH 512
522 #define ET_HASFONT 256
523 #define ET_X3 128
524 #define ET_AUTOSIZE 64 /* MX */
525 #define ET_HASLAYOUT 32
526 #define ET_NOSELECT 16
527 #define ET_BORDER 8
528 #define ET_X1 4
529 #define ET_HTML 2 /* MX? */
530 #define ET_USEOUTLINES 1
531
532 typedef struct _EditTextLayout
533 {
534     U8 align; // 0=left, 1=right, 2=center, 3=justify
535     U16 leftmargin;
536     U16 rightmargin;
537     U16 indent;
538     U16 leading;
539 } EditTextLayout;
540
541 int swf_FontEnumerate(SWF * swf,void (*FontCallback) (U16,U8*));
542 // -> void fontcallback(U16 id,U8 * name); returns number of defined fonts
543
544 int swf_FontExtract(SWF * swf,int id,SWFFONT ** f);
545 // Fetches all available information from DefineFont, DefineFontInfo, DefineText, ...
546 // id = FontID, id=0 -> Extract first Font
547
548 int swf_FontIsItalic(SWFFONT * f);
549 int swf_FontIsBold(SWFFONT * f);
550
551 int swf_FontSetID(SWFFONT * f,U16 id);
552 int swf_FontReduce(SWFFONT * f,FONTUSAGE * use);
553
554 int swf_FontInitUsage(SWFFONT * f,FONTUSAGE * use);
555 int swf_FontUse(FONTUSAGE * use,U8 * s);
556
557 int swf_FontSetDefine(TAG * t,SWFFONT * f);
558 int swf_FontSetDefine2(TAG * t,SWFFONT * f);
559 int swf_FontSetInfo(TAG * t,SWFFONT * f);
560
561 void swf_FontCreateLayout(SWFFONT*f);
562 void swf_FontAddLayout(SWFFONT * f, int ascent, int descent, int leading);
563
564 int swf_FontExtract_DefineTextCallback(int id,SWFFONT * f,TAG * t,int jobs, 
565         void(*callback)(int*chars, int nr, int id));
566
567 void swf_WriteFont(SWFFONT* font, char* filename);
568 SWFFONT* swf_ReadFont(char* filename);
569
570 void swf_FontFree(SWFFONT * f);
571
572 U32 swf_TextGetWidth(SWFFONT * font,U8 * s,int scale);
573 int swf_TextCountBits(SWFFONT * font,U8 * s,int scale,U8 * gbits,U8 * abits);
574
575 #define SET_TO_ZERO 0x80000000
576 int swf_TextSetInfoRecord(TAG * t,SWFFONT * font,U16 size,RGBA * color,int dx,int dy);
577 int swf_TextSetCharRecord(TAG * t,SWFFONT * font,U8 * s,int scale,U8 gbits,U8 abits);
578
579 int swf_TextPrintDefineText(TAG * t,SWFFONT * f);
580 // Prints text defined in tag t with font f to stdout
581
582 /* notice: if you set the fontid, make sure the corresponding font has layout information */
583 void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, 
584         int maxlength, U16 font, U16 height, EditTextLayout*layout, char*variable);
585
586 SRECT swf_SetDefineText(TAG*tag, SWFFONT*font, RGBA*rgb, char*text, int scale);
587
588 void swf_DrawText(drawer_t*draw, SWFFONT*font, char*text);
589
590 // swffont.c
591
592 SWFFONT* swf_LoadTrueTypeFont(char*filename);
593 SWFFONT* swf_LoadT1Font(char*filename);
594 SWFFONT* swf_LoadFont(char*filename);
595
596 // swfdump.c
597
598 void swf_DumpHeader(FILE * f,SWF * swf);
599 void swf_DumpMatrix(FILE * f,MATRIX * m);
600 void swf_DumpTag(FILE * f,TAG * t); 
601 void swf_DumpSWF(FILE * f,SWF*swf);
602 char* swf_TagGetName(TAG*tag);
603 void swf_DumpFont(SWFFONT * font);
604
605 // swfbutton.c
606
607 // Button States
608
609 #define BS_HIT          0x08
610 #define BS_DOWN         0x04
611 #define BS_OVER         0x02
612 #define BS_UP           0x01
613
614 // Button Conditions
615
616 #define BC_OVERDOWN_IDLE        0x0100
617 #define BC_IDLE_OVERDOWN        0x0080
618 #define BC_OUTDOWN_IDLE         0x0040
619 #define BC_OUTDOWN_OVERDOWN     0x0020
620 #define BC_OVERDOWN_OUTDOWN     0x0010
621 #define BC_OVERDOWN_OVERUP      0x0008
622 #define BC_OVERUP_OVERDOWN      0x0004
623 #define BC_OVERUP_IDLE          0x0002
624 #define BC_IDLE_OVERUP          0x0001
625
626 #define BC_KEY(c) (c<<9)
627
628 #define BC_CURSORLEFT           0x0200
629 #define BC_CURSORRIGHT          0x0400
630 #define BC_POS1                 0x0600
631 #define BC_END                  0x0800
632 #define BC_INSERT               0x0a00
633 #define BC_DELETE               0x0c00
634 #define BC_CLEAR                0x0e00
635 #define BC_BACKSPACE            0x1000
636 #define BC_ENTER                0x1a00
637 #define BC_CURSORUP             0x1c00
638 #define BC_CURSORDOWN           0x1e00
639 #define BC_PAGEUP               0x2000
640 #define BC_PAGEDOWN             0x2200
641 #define BC_TAB                  0x2400
642 #define BC_ESCAPE               0x3600
643 #define BC_SPACE                0x4000
644
645 /* these are probably only valid with linux:
646    Ctrl-A        0x0200
647    Ctrl-X        0x3000
648    Ctrl-Y        0x3200
649    Ctrl-Z        0x3400
650    Escape/Ctrl-[ 0x3600
651    Ctrl-\        0x3800
652    Ctrl-]        0x3a00
653    Ctrl-^        0x3c00
654    Ctrl-/        0x3e00
655    */
656
657 /* everything above 0x4000 is standard ascii:
658    0x4000 ' ' 0x4200 '!' 0x4600 '#' 0x4800 '$' 0x4a00 '%' 0x4c00 '&' ...
659    0x6000 '0' ... 0x7200 '9' 
660    0x8000 '@' 
661    0x8200 'A' ...  0xb400 'Z' 
662    ...
663    0xfc00 '~'
664  */
665
666 // Button Flag
667
668 #define BF_TRACKMENU            0x01
669
670 int swf_ButtonSetRecord(TAG * t,U8 state,U16 id,U16 layer,MATRIX * m,CXFORM * cx);
671 int swf_ButtonSetCondition(TAG * t,U16 condition); // for DefineButton2
672 int swf_ButtonSetFlags(TAG * t,U8 flags);  // necessary for DefineButton2
673 int swf_ButtonPostProcess(TAG * t,int anz_action); // Set all offsets in DefineButton2-Tags (how many conditions to process)
674
675 // swfbits.c
676
677 typedef int JPEGBITS,* LPJPEGBITS; // cover libjpeg structures
678
679 JPEGBITS * swf_SetJPEGBitsStart(TAG * t,int width,int height,int quality);
680 int swf_SetJPEGBitsLines(JPEGBITS * jpegbits,U8 ** data,int n);
681 int swf_SetJPEGBitsLine(JPEGBITS * jpegbits,U8 * data);
682 int swf_SetJPEGBitsFinish(JPEGBITS * jpegbits);
683
684 void swf_GetJPEGSize(char * fname, int*width, int*height);
685
686 int swf_SetJPEGBits(TAG * t,char * fname,int quality);
687 void swf_SetJPEGBits2(TAG * t,U16 width,U16 height,RGBA * bitmap,int quality);
688 int swf_SetJPEGBits3(TAG * tag,U16 width,U16 height,RGBA* bitmap, int quality);
689
690 #define BYTES_PER_SCANLINE(width) ((width+3)&0xfffffffc)
691
692 #define BMF_8BIT        3               // Bitmap formats
693 #define BMF_16BIT       4
694 #define BMF_32BIT       5
695
696 #define BM16_BLUE       0xf800          // Bitmasks for 16 Bit Color
697 #define BM16_RED        0x00f0
698 #define BM16_GREEN      0x000f
699
700 #define BM32_BLUE       0xff000000      // Bitmasks for 32 Bit Color
701 #define BM32_GREEN      0x00ff0000
702 #define BM32_RED        0x0000ff00
703
704 int swf_SetLosslessBits(TAG * t,U16 width,U16 height,void * bitmap,U8 bitmap_flags);
705 int swf_SetLosslessBitsIndexed(TAG * t,U16 width,U16 height,U8 * bitmap,RGBA * palette,U16 ncolors);
706 int swf_SetLosslessBitsGrayscale(TAG * t,U16 width,U16 height,U8 * bitmap);
707
708 // swfsound.c
709 void swf_SetSoundStreamHead(TAG*tag, int avgnumsamples);
710 void swf_SetSoundStreamBlock(TAG*tag, S16*samples, int seek, char first); /* expects 2304 samples */
711 void swf_SetSoundDefine(TAG*tag, S16*samples, int num);
712 void swf_SetSoundInfo(TAG*tag, SOUNDINFO*info);
713
714 // swftools.c
715
716 U8 swf_isDefiningTag(TAG * t);
717 U8 swf_isPseudoDefiningTag(TAG * t);
718 U8 swf_isAllowedSpriteTag(TAG * t);
719 U16 swf_GetDefineID(TAG * t);
720 SRECT swf_GetDefineBBox(TAG * t);
721 void swf_SetDefineID(TAG * t, U16 newid);
722 U16 swf_GetPlaceID(TAG * t); //PLACEOBJECT, PLACEOBJECT2 (sometimes), REMOVEOBJECT
723 int swf_GetDepth(TAG * t); //PLACEOBJECT,PLACEOBJECT2,REMOVEOBJECT,REMOVEOBJECT2,SETTABINDEX
724 char* swf_GetName(TAG * t); //PLACEOBJECT2, FRAMELABEL
725 MATRIX * swf_MatrixJoin(MATRIX * d,MATRIX * s1,MATRIX * s2);
726 MATRIX * swf_MatrixMapTriangle(MATRIX * m,int dx,int dy,
727                     int x0,int y0,int x1,int y1,int x2,int y2);
728 int swf_GetNumUsedIDs(TAG * t);
729 void swf_GetUsedIDs(TAG * t, int * positions);
730 void swf_Relocate(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[a]==0 means id a is free
731 void swf_RelocateDepth(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[d]==0 means depth d is free
732
733 TAG* swf_Concatenate (TAG*list1,TAG*list2); // warning: both list1 and list2 are invalid after this call.
734
735 // swfcgi.c
736
737 void swf_uncgi();  // same behaviour as Steven Grimm's uncgi-library
738
739 // swfaction.c
740
741 typedef struct _ActionTAG 
742 { U8            op;
743   U16           len;
744   U8 *          data;
745
746   struct _ActionTAG * next;
747   struct _ActionTAG * prev;
748
749   struct _ActionTAG * parent;
750   U8 tmp[4]; // store small operands here.
751 } ActionTAG;
752
753 typedef struct _ActionMarker
754 {
755   ActionTAG* atag;
756 } ActionMarker;
757
758 ActionTAG* swf_ActionGet(TAG*tag);
759 void swf_ActionFree(ActionTAG*tag);
760 void swf_ActionSet(TAG*tag, ActionTAG*actions);
761 void swf_DumpActions(ActionTAG*atag, char*prefix);
762 void swf_ActionEnumerateURLs(ActionTAG*atag, char*(*callback)(char*));
763 void swf_ActionEnumerateTargets(ActionTAG*atag, char*(*callback)(char*));
764 void swf_ActionEnumerateStrings(ActionTAG*atag, char*(*callback)(char*));
765
766 // using action/actioncompiler.h:
767 ActionTAG* swf_ActionCompile(const char* source, int version);
768
769 ActionTAG* action_End(ActionTAG*atag);
770 ActionTAG* action_NextFrame(ActionTAG*atag);
771 ActionTAG* action_PreviousFrame(ActionTAG*atag);
772 ActionTAG* action_Play(ActionTAG*atag);
773 ActionTAG* action_Stop(ActionTAG*atag);
774 ActionTAG* action_ToggleQuality(ActionTAG*atag);
775 ActionTAG* action_StopSounds(ActionTAG*atag);
776 ActionTAG* action_Add(ActionTAG*atag);
777 ActionTAG* action_Subtract(ActionTAG*atag);
778 ActionTAG* action_Multiply(ActionTAG*atag);
779 ActionTAG* action_Divide(ActionTAG*atag);
780 ActionTAG* action_Equals(ActionTAG*atag);
781 ActionTAG* action_Less(ActionTAG*atag);
782 ActionTAG* action_And(ActionTAG*atag);
783 ActionTAG* action_Or(ActionTAG*atag);
784 ActionTAG* action_Not(ActionTAG*atag);
785 ActionTAG* action_StringEquals(ActionTAG*atag);
786 ActionTAG* action_StringLength(ActionTAG*atag);
787 ActionTAG* action_StringExtract(ActionTAG*atag);
788 ActionTAG* action_Pop(ActionTAG*atag);
789 ActionTAG* action_ToInteger(ActionTAG*atag);
790 ActionTAG* action_GetVariable(ActionTAG*atag);
791 ActionTAG* action_SetVariable(ActionTAG*atag);
792 ActionTAG* action_SetTarget2(ActionTAG*atag);
793 ActionTAG* action_StringAdd(ActionTAG*atag);
794 ActionTAG* action_GetProperty(ActionTAG*atag);
795 ActionTAG* action_SetProperty(ActionTAG*atag);
796 ActionTAG* action_CloneSprite(ActionTAG*atag);
797 ActionTAG* action_RemoveSprite(ActionTAG*atag);
798 ActionTAG* action_Trace(ActionTAG*atag);
799 ActionTAG* action_StartDrag(ActionTAG*atag);
800 ActionTAG* action_EndDrag(ActionTAG*atag);
801 ActionTAG* action_StringLess(ActionTAG*atag);
802 ActionTAG* action_RandomNumber(ActionTAG*atag);
803 ActionTAG* action_MBStringLength(ActionTAG*atag);
804 ActionTAG* action_CharToAscii(ActionTAG*atag);
805 ActionTAG* action_AsciiToChar(ActionTAG*atag);
806 ActionTAG* action_GetTime(ActionTAG*atag);
807 ActionTAG* action_MBStringExtract(ActionTAG*atag);
808 ActionTAG* action_MBCharToAscii(ActionTAG*atag);
809 ActionTAG* action_MBAsciiToChar(ActionTAG*atag);
810 ActionTAG* action_Delete(ActionTAG*atag);
811 ActionTAG* action_Delete2(ActionTAG*atag);
812 ActionTAG* action_DefineLocal(ActionTAG*atag);
813 ActionTAG* action_CallFunction(ActionTAG*atag);
814 ActionTAG* action_Return(ActionTAG*atag);
815 ActionTAG* action_Modulo(ActionTAG*atag);
816 ActionTAG* action_NewObject(ActionTAG*atag);
817 ActionTAG* action_DefineLocal2(ActionTAG*atag);
818 ActionTAG* action_InitArray(ActionTAG*atag);
819 ActionTAG* action_Makehash(ActionTAG*atag);
820 ActionTAG* action_TypeOf(ActionTAG*atag);
821 ActionTAG* action_TargetPath(ActionTAG*atag);
822 ActionTAG* action_Enumerate(ActionTAG*atag);
823 ActionTAG* action_Add2(ActionTAG*atag);
824 ActionTAG* action_Less2(ActionTAG*atag);
825 ActionTAG* action_Equals2(ActionTAG*atag);
826 ActionTAG* action_ToNumber(ActionTAG*atag);
827 ActionTAG* action_ToString(ActionTAG*atag);
828 ActionTAG* action_PushDuplicate(ActionTAG*atag);
829 ActionTAG* action_StackSwap(ActionTAG*atag);
830 ActionTAG* action_GetMember(ActionTAG*atag);
831 ActionTAG* action_SetMember(ActionTAG*atag);
832 ActionTAG* action_Increment(ActionTAG*atag);
833 ActionTAG* action_Decrement(ActionTAG*atag);
834 ActionTAG* action_CallMethod(ActionTAG*atag);
835 ActionTAG* action_NewMethod(ActionTAG*atag);
836 ActionTAG* action_BitAnd(ActionTAG*atag);
837 ActionTAG* action_BitOr(ActionTAG*atag);
838 ActionTAG* action_BitXor(ActionTAG*atag);
839 ActionTAG* action_BitLShift(ActionTAG*atag);
840 ActionTAG* action_BitRShift(ActionTAG*atag);
841 ActionTAG* action_BitURShift(ActionTAG*atag);
842 ActionTAG* action_GotoFrame(ActionTAG*atag, U16 frame);
843 ActionTAG* action_GetUrl(ActionTAG*atag, char* url, char* label);
844 ActionTAG* action_StoreRegister(ActionTAG*atag, U8 reg);
845 ActionTAG* action_Constantpool(ActionTAG*atag, char* constantpool);
846 ActionTAG* action_WaitForFrame(ActionTAG*atag, U16 frame, U8 skip);
847 ActionTAG* action_SetTarget(ActionTAG*atag, char* target);
848 ActionTAG* action_GotoLabel(ActionTAG*atag, char* label);
849 ActionTAG* action_WaitForFrame2(ActionTAG*atag, U8 skip);
850 ActionTAG* action_With(ActionTAG*atag, char*object);
851 ActionTAG* action_PushString(ActionTAG*atag, char*str);
852 ActionTAG* action_PushFloat(ActionTAG*atag, float f);
853 ActionTAG* action_PushNULL(ActionTAG*atag);
854 ActionTAG* action_PushRegister(ActionTAG*atag, U8 reg);
855 ActionTAG* action_PushBoolean(ActionTAG*atag, char c);
856 ActionTAG* action_PushDouble(ActionTAG*atag, double d);
857 ActionTAG* action_PushInt(ActionTAG*atag, int i);
858 ActionTAG* action_PushLookup(ActionTAG*atag, U8 index);
859 ActionTAG* action_Jump(ActionTAG*atag, U16 branch);
860 ActionTAG* action_GetUrl2(ActionTAG*atag, U8 method);
861 ActionTAG* action_DefineFunction(ActionTAG*atag, U8*data, int len);
862 ActionTAG* action_If(ActionTAG*atag, U16 branch);
863 ActionTAG* action_Call(ActionTAG*atag);
864 ActionTAG* action_GotoFrame2(ActionTAG*atag, U8 method);
865 ActionMarker action_setMarker(ActionTAG*atag);
866 void action_fixjump(ActionMarker m1, ActionMarker m2);
867
868 // swfobject.c
869
870 // The following 3 routines only use placeobject2:
871
872 int swf_ObjectPlace(TAG * t,U16 id,U16 depth,MATRIX * m,CXFORM * cx,U8 * name);
873 int swf_ObjectPlaceClip(TAG * t,U16 id,U16 depth,MATRIX * m,CXFORM * cx,U8 * name, U16 clipaction);
874 int swf_ObjectMove(TAG * t,U16 depth,MATRIX * m,CXFORM * cx);
875
876 typedef struct _SWFPLACEOBJECT {
877     U16 depth;
878     U16 id; // may be 0
879     bool move; //true: move/replace character, false: set character
880     MATRIX matrix;
881     CXFORM cxform;
882     U16 ratio;
883     U8*name;
884     U16 clipdepth;
885     ActionTAG* actions;
886 } SWFPLACEOBJECT;
887
888 void swf_SetPlaceObject(TAG * t,SWFPLACEOBJECT* obj);
889 void swf_GetPlaceObject(TAG * t,SWFPLACEOBJECT* obj);
890 void swf_PlaceObjectFree(SWFPLACEOBJECT* obj);
891
892 // swfvideo.c
893
894 typedef struct _VIDEOSTREAM
895 {
896     int width;
897     int height;
898     int linex;
899
900     int owidth;
901     int oheight;
902     int olinex;
903
904     int frame;
905     YUV*oldpic;
906     YUV*current;
907     int bbx;
908     int bby;
909     int*mvdx;
910     int*mvdy;
911     int quant;
912
913     /* modifyable: */
914     int do_motion; //enable motion compensation (slow!)
915
916 } VIDEOSTREAM;
917
918 void swf_SetVideoStreamDefine(TAG*tag, VIDEOSTREAM*stream, U16 frames, U16 width, U16 height);
919 void swf_SetVideoStreamIFrame(TAG*tag, VIDEOSTREAM*s, RGBA*pic, int quant/* 1-31, 1=best quality, 31=best compression*/);
920 void swf_SetVideoStreamPFrame(TAG*tag, VIDEOSTREAM*s, RGBA*pic, int quant/* 1-31, 1=best quality, 31=best compression*/);
921 void swf_VideoStreamClear(VIDEOSTREAM*stream);
922
923 #ifdef __cplusplus
924 }
925 #endif
926
927 #endif
928