X-Git-Url: http://git.asbjorn.biz/?p=swftools.git;a=blobdiff_plain;f=lib%2Frfxswf.h;h=07b9ea00d7f70fb1ed5cd6a45d3951c773e6d9a5;hp=c9bdc9ebf48dfd4b7c9d765df5ba54fe18533868;hb=133453cc112df7e7d5ce35f3dde5178303154da5;hpb=74021a5785a3b96e71a515d25fb91cd4e8cbbea9 diff --git a/lib/rfxswf.h b/lib/rfxswf.h index c9bdc9e..07b9ea0 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -36,8 +36,12 @@ extern "C" { #include #include "../config.h" #include "./bitio.h" +#include "./drawer.h" #define DEBUG_RFXSWF +#ifdef RFXSWF_DISABLESOUND +#define NO_MP3 +#endif #ifndef TRUE #define TRUE (1) @@ -77,6 +81,9 @@ typedef signed char S8; typedef signed long SFIXED; typedef signed long SCOORD; +#define SCOORD_MAX 0x7fffffff +#define SCOORD_MIN -0x80000000 + // Basic Structures typedef struct _SPOINT @@ -338,8 +345,12 @@ SRECT swf_TurnRect(SRECT r, MATRIX* m); #define ST_VIDEOFRAME 61 #define ST_DEFINEFONTINFO2 62 #define ST_MX4 63 /*(?) */ +#define ST_SCRIPTLIMITS 65 /* version 7- u16 maxrecursedepth, u16 scripttimeoutseconds */ +#define ST_SETTABINDEX 66 /* version 7- u16 depth(!), u16 tab order value */ +/* custom tags- only valid for swftools */ #define ST_REFLEX 777 /* to identify generator software */ +#define ST_GLYPHNAMES 778 // Advanced Funtions @@ -442,39 +453,14 @@ void swf_DumpShape(SHAPE2*shape2); // swfdraw.c -typedef struct _FPOINT -{ - float x,y; -} FPOINT; +void swf_Shape01DrawerInit(drawer_t*draw, TAG*tag); +void swf_Shape11DrawerInit(drawer_t*draw, TAG*tag); +SHAPE* swf_ShapeDrawerToShape(drawer_t*draw); +SRECT swf_ShapeDrawerGetBBox(drawer_t*draw); -typedef struct _SWFSHAPEDRAWER -{ - FPOINT pos; - SHAPE*shape; - TAG*tag; - int tagfree; - int lastx; - int lasty; - SRECT bbox; - char isfinished; -} SWFSHAPEDRAWER; - -void swf_DrawerInit(SWFSHAPEDRAWER*draw, TAG*tag); -void swf_DrawerMoveTo(SWFSHAPEDRAWER*draw, FPOINT * to); -void swf_DrawerLineTo(SWFSHAPEDRAWER*draw, FPOINT * to); -void swf_DrawerSplineTo(SWFSHAPEDRAWER*draw, FPOINT * control1, FPOINT* to); -void swf_DrawerCubicTo(SWFSHAPEDRAWER*draw, FPOINT* control1, FPOINT* control2, FPOINT* to); -void swf_DrawerConicTo(SWFSHAPEDRAWER*draw, FPOINT* control, FPOINT* to); -void swf_DrawerFinish(SWFSHAPEDRAWER*draw); -SHAPE* swf_DrawerToShape(SWFSHAPEDRAWER*draw); - -void swf_DrawString(SWFSHAPEDRAWER*draw, const char*source); +void swf_DrawString(drawer_t*draw, const char*source); -// swffont.c - -// does not support wide characters ! - -#define MAX_CHAR_PER_FONT 512 +// swftext.c typedef struct _KERNING { @@ -518,10 +504,12 @@ typedef struct _SWFFONT int * ascii2glyph; SWFGLYPH * glyph; U8 language; + char ** glyphnames; } SWFFONT, * LPSWFFONT; +// does not support wide characters ! typedef struct _FONTUSAGE -{ U8 code[MAX_CHAR_PER_FONT]; +{ U8* code; } FONTUSAGE, * LPFONTUSAGE; #define ET_HASTEXT 32768 @@ -563,7 +551,7 @@ int swf_FontIsBold(SWFFONT * f); int swf_FontSetID(SWFFONT * f,U16 id); int swf_FontReduce(SWFFONT * f,FONTUSAGE * use); -int swf_FontInitUsage(FONTUSAGE * use); +int swf_FontInitUsage(SWFFONT * f,FONTUSAGE * use); int swf_FontUse(FONTUSAGE * use,U8 * s); int swf_FontSetDefine(TAG * t,SWFFONT * f); @@ -597,7 +585,13 @@ void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, SRECT swf_SetDefineText(TAG*tag, SWFFONT*font, RGBA*rgb, char*text, int scale); -void swf_DrawText(SWFSHAPEDRAWER*draw, SWFFONT*font, char*text); +void swf_DrawText(drawer_t*draw, SWFFONT*font, char*text); + +// swffont.c + +SWFFONT* swf_LoadTrueTypeFont(char*filename); +SWFFONT* swf_LoadT1Font(char*filename); +SWFFONT* swf_LoadFont(char*filename); // swfdump.c @@ -711,18 +705,12 @@ 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); -#ifndef RFXSWF_DISABLESOUND - // swfsound.c void swf_SetSoundStreamHead(TAG*tag, int avgnumsamples); void swf_SetSoundStreamBlock(TAG*tag, S16*samples, int seek, char first); /* expects 2304 samples */ - void swf_SetSoundDefine(TAG*tag, S16*samples, int num); - void swf_SetSoundInfo(TAG*tag, SOUNDINFO*info); -#endif // RFXSWF_DISABLESOUND - // swftools.c U8 swf_isDefiningTag(TAG * t); @@ -732,7 +720,7 @@ U16 swf_GetDefineID(TAG * t); SRECT swf_GetDefineBBox(TAG * t); void swf_SetDefineID(TAG * t, U16 newid); U16 swf_GetPlaceID(TAG * t); //PLACEOBJECT, PLACEOBJECT2 (sometimes), REMOVEOBJECT -U16 swf_GetDepth(TAG * t); //PLACEOBJECT,PLACEOBJECT2,REMOVEOBJECT,REMOVEOBJECT2 +int swf_GetDepth(TAG * t); //PLACEOBJECT,PLACEOBJECT2,REMOVEOBJECT,REMOVEOBJECT2,SETTABINDEX char* swf_GetName(TAG * t); //PLACEOBJECT2, FRAMELABEL MATRIX * swf_MatrixJoin(MATRIX * d,MATRIX * s1,MATRIX * s2); MATRIX * swf_MatrixMapTriangle(MATRIX * m,int dx,int dy, @@ -740,6 +728,7 @@ MATRIX * swf_MatrixMapTriangle(MATRIX * m,int dx,int dy, int swf_GetNumUsedIDs(TAG * t); void swf_GetUsedIDs(TAG * t, int * positions); void swf_Relocate(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[a]==0 means id a is free +void swf_RelocateDepth(SWF*swf, char*bitmap); // bitmap is 65536 bytes, bitmap[d]==0 means depth d is free // swfcgi.c @@ -772,6 +761,9 @@ void swf_ActionEnumerateURLs(ActionTAG*atag, char*(*callback)(char*)); void swf_ActionEnumerateTargets(ActionTAG*atag, char*(*callback)(char*)); void swf_ActionEnumerateStrings(ActionTAG*atag, char*(*callback)(char*)); +// using action/actioncompiler.h: +ActionTAG* swf_ActionCompile(const char* source, int version); + ActionTAG* action_End(ActionTAG*atag); ActionTAG* action_NextFrame(ActionTAG*atag); ActionTAG* action_PreviousFrame(ActionTAG*atag);