X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Frfxswf.h;h=78ceda053c57e512d92da84b60394925e2a22095;hb=3cf7bdf11b3f690167c55c35fb21eb24018678dc;hp=81ccf9f1abb337b5947804d823bba2469baaeeaf;hpb=5591193a032de5fe7b6f61954c19b51a3709507e;p=swftools.git diff --git a/lib/rfxswf.h b/lib/rfxswf.h index 81ccf9f..78ceda0 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -18,7 +18,9 @@ #include #include #include +#include #include "../config.h" +#include "bladeenc/codec.h" #define DEBUG_RFXSWF @@ -29,14 +31,28 @@ #define FALSE (0) #endif + +/* little/big endian stuff */ + +//#define SWAP16(s) ((U16) ((U8*)&s)[0] | ((U16) ((U8*)&s)[1] << 8)) +//#define SWAP32(s) ((U32) ((U8*)&s)[0] | ((U32) ((U8*)&s)[1] << 8) | ((U32) ((U8*)&s)[2] << 16) | ((U32) ((U8*)&s)[3] << 24)) + +#define PUT16(ptr,x) ((U8*)(ptr))[0]=(U8)(x);((U8*)(ptr))[1]=(U8)((x)>>8); +#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); +#define GET16(ptr) (((U16)(((U8*)(ptr))[0]))+(((U16)(((U8*)(ptr))[1]))<<8)) +#define GET32(ptr) (((U16)(((U8*)(ptr))[0]))+(((U16)(((U8*)(ptr))[1]))<<8)+(((U16)(((U8*)(ptr))[2]))<<16)+(((U16)(((U8*)(ptr))[3]))<<24)) + #ifdef WORDS_BIGENDIAN -#define SWAP16(s) ((U16) ((U8*)&s)[0] | ((U16) ((U8*)&s)[1] << 8)) -#define SWAP32(s) ((U32) ((U8*)&s)[0] | ((U32) ((U8*)&s)[1] << 8) | ((U32) ((U8*)&s)[2] << 16) | ((U32) ((U8*)&s)[3] << 24)) +#define SWAP16(s) ((((s)>>8)&0x00ff)|(((s)<<8)&0xff00)) +#define SWAP32(s) (SWAP16(((s)>>16)&0x0000ffff)|((SWAP16(s)<<16)&0xffff0000)) +#define REVERSESWAP16(x) (x) +#define REVERSESWAP32(x) (x) #else -#define SWAP16(x) x -#define SWAP32(x) x +#define SWAP16(x) (x) +#define SWAP32(x) (x) +#define REVERSESWAP16(s) ((((s)>>8)&0x00ff)|(((s)<<8)&0xff00)) +#define REVERSESWAP32(s) (REVERSESWAP16(((s)>>16)&0x0000ffff)|((REVERSESWAP16(s)<<16)&0xffff0000)) #endif - // SWF Types typedef unsigned long U32; @@ -135,6 +151,15 @@ int swf_ReadSWF(int handle,SWF * swf); // Reads SWF to memory (malloc'ed), int swf_WriteSWF(int handle,SWF * swf); // Writes SWF to file, returns length or <0 if fails int swf_WriteCGI(SWF * swf); // Outputs SWF with valid CGI header to stdout void swf_FreeTags(SWF * swf); // Frees all malloc'ed memory for swf + +// for streaming: +int swf_WriteHeader(int handle,SWF * swf); // Writes Header of swf to file +int swf_WriteTag(int handle,TAG * tag); // Writes TAG to file + +// folding/unfolding: + +void swf_FoldAll(SWF*swf); +void swf_FoldSprite(TAG*tag); TAG * swf_InsertTag(TAG * after,U16 id); // updates frames, if necessary int swf_DeleteTag(TAG * t); @@ -204,6 +229,7 @@ int swf_SetRGBA(TAG * t,RGBA * col); #define ST_PLACEOBJECT 4 #define ST_REMOVEOBJECT 5 #define ST_DEFINEBITS 6 +#define ST_DEFINEBITSJPEG 6 #define ST_DEFINEBUTTON 7 #define ST_JPEGTABLES 8 #define ST_SETBACKGROUNDCOLOR 9 @@ -338,6 +364,12 @@ typedef struct SHAPE * shape; } SWFGLYPH; +#define FONT_STYLE_BOLD 1 +#define FONT_STYLE_ITALIC 2 +#define FONT_ENCODING_UNICODE 1 +#define FONT_ENCODING_ANSI 2 +#define FONT_ENCODING_SHIFTJIS 4 + typedef struct _SWFFONT { int id; // -1 = not set U8 version; // 0 = not set, 1 = definefont, 2 = definefont2 @@ -345,7 +377,10 @@ typedef struct _SWFFONT SWFLAYOUT * layout; U16 numchars; U16 maxascii; // highest mapped ascii value - U8 flags; // bold/italic/unicode/ansi ... + + U8 style; + U8 encoding; + U16 * glyph2ascii; int * ascii2glyph; SWFGLYPH * glyph; @@ -355,6 +390,32 @@ typedef struct _FONTUSAGE { U8 code[MAX_CHAR_PER_FONT]; } FONTUSAGE, * LPFONTUSAGE; +#define ET_HASTEXT 32768 +#define ET_WORDWRAP 16384 +#define ET_MULTILINE 8192 +#define ET_PASSWORD 4096 +#define ET_READONLY 2048 +#define ET_HASTEXTCOLOR 1024 +#define ET_HASMAXLENGTH 512 +#define ET_HASFONT 256 +#define ET_X3 128 +#define ET_X2 64 +#define ET_HASLAYOUT 32 +#define ET_NOSELECT 16 +#define ET_BORDER 8 +#define ET_X1 4 +#define ET_X0 2 +#define ET_USEOUTLINES 1 + +typedef struct _EditTextLayout +{ + U8 align; // 0=left, 1=right, 2=center, 3=justify + U16 leftmargin; + U16 rightmargin; + U16 indent; + U16 leading; +} EditTextLayout; + int swf_FontEnumerate(SWF * swf,void (*FontCallback) (U16,U8*)); // -> void fontcallback(U16 id,U8 * name); returns number of defined fonts @@ -372,8 +433,11 @@ int swf_FontInitUsage(FONTUSAGE * use); int swf_FontUse(FONTUSAGE * use,U8 * s); int swf_FontSetDefine(TAG * t,SWFFONT * f); +int swf_FontSetDefine2(TAG * t,SWFFONT * f); int swf_FontSetInfo(TAG * t,SWFFONT * f); +void swf_FontAddLayout(SWFFONT * f, int ascent, int descent, int leading); + int swf_FontExtract_DefineTextCallback(int id,SWFFONT * f,TAG * t,int jobs, void(*callback)(int*chars, int nr, int id)); @@ -395,6 +459,10 @@ int swf_TextSetCharRecord(TAG * t,SWFFONT * font,U8 * s,int scale,U8 gbits,U8 ab int swf_TextPrintDefineText(TAG * t,SWFFONT * f); // Prints text defined in tag t with font f to stdout +/* notice: if you set the fontid, make sure the corresponding font has layout information */ +void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, + int maxlength, U16 font, U16 height, EditTextLayout*layout, char*variable); + // swfdump.c void swf_DumpHeader(FILE * f,SWF * swf); @@ -510,6 +578,10 @@ int swf_SetLosslessBits(TAG * t,U16 width,U16 height,void * bitmap,U8 bitmap_fla int swf_SetLosslessBitsIndexed(TAG * t,U16 width,U16 height,U8 * bitmap,RGBA * palette,U16 ncolors); int swf_SetLosslessBitsGrayscale(TAG * t,U16 width,U16 height,U8 * bitmap); +// swfsound.c +void swf_SetSoundStreamHead(TAG*tag, U16 avgnumsamples); +void swf_SetSoundStreamBlock(TAG*tag, S16*samples, int numsamples, char first); + // swftools.c U8 swf_isDefiningTag(TAG * t);