X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Frfxswf.h;h=fc39f3fa761c93b7b9a6d6ec877f5df8fd7bb1ec;hb=e6b4ceefbdfaa2e2a2837105b4255262bae797de;hp=c3783d5003725c48c293883ec560c89d066d1379;hpb=0e4f5172ce5736dd03f867e6e8cc8d9a56b2fa50;p=swftools.git diff --git a/lib/rfxswf.h b/lib/rfxswf.h index c3783d5..fc39f3f 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -30,6 +30,7 @@ extern "C" { #include #include +#include #include #include #include @@ -71,6 +72,16 @@ extern "C" { #define REVERSESWAP32(s) (REVERSESWAP16(((s)>>16)&0x0000ffff)|((REVERSESWAP16(s)<<16)&0xffff0000)) #endif +#define ALLOC_ARRAY(type, num) (((type)*)rfxalloc(sizeof(type)*(num))) +void* rfx_alloc(int size); +void* rfx_calloc(int size); +void* rfx_realloc(void*data, int size); +void rfx_free(void*data); +#ifdef MEMORY_INFO +long rfx_memory_used(); +char* rfx_memory_used_str(); +#endif + // SWF Types typedef unsigned long U32; @@ -191,6 +202,7 @@ int swf_WriteSWF(int handle,SWF * swf); // Writes SWF to file, returns lengt int swf_WriteSWC(int handle, SWF * swf); // for convenience, equal to swf->compressed=1;swf_WriteSWF(..) 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 +SWF* swf_CopySWF(SWF*swf); // for streaming: int swf_WriteHeader(int handle,SWF * swf); // Writes Header of swf to file @@ -220,6 +232,7 @@ int swf_DeleteTag(TAG * t); void swf_ClearTag(TAG * t); //frees tag data void swf_ResetTag(TAG*tag, U16 id); //set's tag position and length to 0, without freeing it +TAG* swf_CopyTag(TAG*tag, TAG*to_copy); //stores a copy of another tag into this taglist void swf_SetTagPos(TAG * t,U32 pos); // resets Bitcount U32 swf_GetTagPos(TAG * t); @@ -351,6 +364,12 @@ typedef struct _LINESTYLE RGBA color; } LINESTYLE, * LPLINESTYLE; +#define FILL_SOLID 0x00 +#define FILL_LINEAR 0x10 // Gradient +#define FILL_RADIAL 0x12 +#define FILL_TILED 0x40 // Bitmap +#define FILL_CLIPPED 0x41 + typedef struct _FILLSTYLE { U8 type; RGBA color; @@ -445,6 +464,9 @@ void swf_ParseDefineShape(TAG*tag, SHAPE2*shape); void swf_Shape2ToShape(SHAPE2*shape2, SHAPE*shape); void swf_SetShape2(TAG*tag, SHAPE2*shape2); +void swf_RecodeShapeData(U8*data, int bitlen, int in_bits_fill, int in_bits_line, + U8**destdata, U32*destbitlen, int out_bits_fill, int out_bits_line); + // swfdraw.c void swf_Shape10DrawerInit(drawer_t*draw, TAG*tag); @@ -537,7 +559,7 @@ typedef struct _EditTextLayout U16 leading; } EditTextLayout; -int swf_FontEnumerate(SWF * swf,void (*FontCallback) (U16,U8*)); +int swf_FontEnumerate(SWF * swf,void (*FontCallback) (void*,U16,U8*), void*self); // -> void fontcallback(U16 id,U8 * name); returns number of defined fonts int swf_FontExtract(SWF * swf,int id,SWFFONT ** f); @@ -693,6 +715,7 @@ void swf_GetJPEGSize(char * fname, int*width, int*height); int swf_SetJPEGBits(TAG * t,char * fname,int quality); void swf_SetJPEGBits2(TAG * t,U16 width,U16 height,RGBA * bitmap,int quality); int swf_SetJPEGBits3(TAG * tag,U16 width,U16 height,RGBA* bitmap, int quality); +RGBA* swf_JPEG2TagToImage(TAG*tag, int*width, int*height); #define BYTES_PER_SCANLINE(width) ((width+3)&0xfffffffc) @@ -703,6 +726,9 @@ int swf_SetJPEGBits3(TAG * tag,U16 width,U16 height,RGBA* bitmap, int quality); int swf_SetLosslessBits(TAG * t,U16 width,U16 height,void * bitmap,U8 bitmap_flags); 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); +RGBA* swf_DefineLosslessBitsTagToImage(TAG*tag, int*width, int*height); + +RGBA* swf_ExtractImage(TAG*tag, int*dwidth, int*dheight); // swfsound.c void swf_SetSoundStreamHead(TAG*tag, int avgnumsamples); @@ -712,9 +738,13 @@ void swf_SetSoundInfo(TAG*tag, SOUNDINFO*info); // swftools.c +void swf_Optimize(SWF*swf); U8 swf_isDefiningTag(TAG * t); U8 swf_isPseudoDefiningTag(TAG * t); U8 swf_isAllowedSpriteTag(TAG * t); +U8 swf_isImageTag(TAG*tag); +U8 swf_isShapeTag(TAG*tag); + U16 swf_GetDefineID(TAG * t); SRECT swf_GetDefineBBox(TAG * t); void swf_SetDefineID(TAG * t, U16 newid); @@ -921,6 +951,25 @@ void swf_SetVideoStreamPFrame(TAG*tag, VIDEOSTREAM*s, RGBA*pic, int quant/* 1-31 void swf_SetVideoStreamMover(TAG*tag, VIDEOSTREAM*s, signed char* movex, signed char* movey, void** image, int quant); void swf_VideoStreamClear(VIDEOSTREAM*stream); +// swfrender.c + +typedef struct RENDERBUF +{ + int width; + int height; + int posx,posy; + void*internal; +} RENDERBUF; + +void swf_Render_Init(RENDERBUF*buf, int posx, int posy, int width, int height, char antialize, int scale); +void swf_Render_SetBackground(RENDERBUF*buf, RGBA*img, int width, int height); +void swf_Render_SetBackgroundColor(RENDERBUF*buf, RGBA color); +RGBA* swf_Render(RENDERBUF*dest); +void swf_RenderShape(RENDERBUF*dest, SHAPE2*shape, MATRIX*m, CXFORM*c, U16 depth,U16 clipdepth); +void swf_Render_AddImage(RENDERBUF*buf, U16 id, RGBA*img, int width, int height); +void swf_Render_ClearCanvas(RENDERBUF*dest); +void swf_Render_Delete(RENDERBUF*dest); + #ifdef __cplusplus } #endif