X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Frfxswf.h;h=fe3c7e12c72d124376769d8d7cd31cb70aa35326;hb=0784a8a882e7b98299fb6a90f0f9a7ebb322562b;hp=21301b5c5d5c4c5a4a297b6bbade03ef949fcf40;hpb=b9319467a11d6cc449505955298e578571a220a1;p=swftools.git diff --git a/lib/rfxswf.h b/lib/rfxswf.h index 21301b5..fe3c7e1 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -5,7 +5,7 @@ Part of the swftools package. Copyright (c) 2000, 2001 Rainer Böhme - + This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or @@ -19,20 +19,18 @@ You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ - + #ifndef __RFX_SWF_INCLUDED__ #define __RFX_SWF_INCLUDED__ -#ifdef __cplusplus -extern "C" { -#endif - #include #include #include #include +#ifndef WIN32 #include +#endif #include #include #include "../config.h" @@ -41,6 +39,10 @@ extern "C" { #include "./mem.h" #include "./types.h" +#ifdef __cplusplus +extern "C" { +#endif + #define DEBUG_RFXSWF #ifdef RFXSWF_DISABLESOUND #define NO_MP3 @@ -123,13 +125,13 @@ typedef struct _TAG // NEVER access a Tag-Struct directly ! U8 readBit; // for Bit-Manipulating Functions [read] U8 writeBit; // [write] - + } TAG; #define swf_ResetReadBits(tag) if (tag->readBit) { tag->pos++; tag->readBit = 0; } #define swf_ResetWriteBits(tag) if (tag->writeBit) { tag->writeBit = 0; } -typedef struct _SOUNDINFO +typedef struct _SOUNDINFO { U8 stop; U8 nomultiple; //continue playing if already started @@ -188,7 +190,7 @@ int swf_IsFolded(TAG*tag); void swf_OptimizeTagOrder(SWF*swf); // basic routines: - + TAG * swf_InsertTag(TAG * after,U16 id); // updates frames, if necessary TAG * swf_InsertTagBefore(SWF*swf, TAG * before,U16 id); // like InsertTag, but insert tag before argument int swf_DeleteTag(TAG * t); @@ -196,7 +198,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); @@ -227,7 +229,7 @@ int swf_SetU8(TAG * t,U8 v); // resets Bitcount int swf_SetU16(TAG * t,U16 v); void swf_SetS16(TAG * t,int v); int swf_SetU32(TAG * t,U32 v); -#define swf_SetString(t,s) swf_SetBlock(t,s,strlen(s)+1) +#define swf_SetString(t,s) swf_SetBlock(t,s,strlen((const char *)s)+1) //int swf_GetPoint(TAG * t,SPOINT * p); // resets Bitcount int swf_GetRect(TAG * t,SRECT * r); @@ -270,7 +272,7 @@ SRECT swf_TurnRect(SRECT r, MATRIX* m); #define ST_PLACEOBJECT 4 #define ST_REMOVEOBJECT 5 #define ST_DEFINEBITS 6 -#define ST_DEFINEBITSJPEG 6 +#define ST_DEFINEBITSJPEG 6 #define ST_DEFINEBUTTON 7 #define ST_JPEGTABLES 8 #define ST_SETBACKGROUNDCOLOR 9 @@ -326,10 +328,15 @@ SRECT swf_TurnRect(SRECT r, MATRIX* m); #define ST_DEFINEFONTALIGNZONES 73 /* version 8 */ #define ST_CSMTEXTSETTINGS 74 /* version 8 */ #define ST_DEFINEFONT3 75 /* version 8 */ +#define ST_SYMBOLCLASS 76 /* version 9 */ #define ST_METADATA 77 /* version 8 */ #define ST_DEFINESCALINGGRID 78 /* version 8 */ +#define ST_DOABC 82 /* version 9 */ #define ST_DEFINESHAPE4 83 /* version 8 */ #define ST_DEFINEMORPHSHAPE2 84 /* version 8 */ +#define ST_SCENEDESCRIPTION 86 /* version 9 */ +#define ST_DEFINEBINARY 87 /* version 9 */ +#define ST_DEFINEFONTNAME 88 /* version 9 */ /* custom tags- only valid for swftools */ #define ST_REFLEX 777 /* to identify generator software */ @@ -353,23 +360,23 @@ typedef struct _LINESTYLE typedef struct _FILLSTYLE { U8 type; RGBA color; - MATRIX m; + MATRIX m; U16 id_bitmap; GRADIENT gradient; } FILLSTYLE; - + typedef struct _SHAPE // NEVER access a Shape-Struct directly ! -{ +{ struct { LINESTYLE * data; U16 n; } linestyle; - - struct + + struct { FILLSTYLE * data; U16 n; } fillstyle; - + struct { U16 fill; U16 line; @@ -392,9 +399,10 @@ typedef struct _SHAPE2 SRECT* bbox; // may be NULL } SHAPE2; +enum SHAPELINETYPE {moveTo, lineTo, splineTo}; typedef struct _SHAPELINE { - enum {moveTo, lineTo, splineTo} type; + enum SHAPELINETYPE type; SCOORD x,y; SCOORD sx,sy; //only if type==splineTo int fillstyle0; @@ -446,7 +454,7 @@ void swf_DumpShape(SHAPE2*shape2); void swf_ParseDefineShape(TAG*tag, SHAPE2*shape); void swf_SetShape2(TAG*tag, SHAPE2*shape2); -void swf_RecodeShapeData(U8*data, int bitlen, int in_bits_fill, int in_bits_line, +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 @@ -491,7 +499,7 @@ typedef struct _FONTUSAGE #define FONT_STYLE_BOLD 1 #define FONT_STYLE_ITALIC 2 #define FONT_ENCODING_UNICODE 1 -#define FONT_ENCODING_ANSI 2 +#define FONT_ENCODING_ANSI 2 #define FONT_ENCODING_SHIFTJIS 4 typedef struct _SWFFONT @@ -501,7 +509,7 @@ typedef struct _SWFFONT SWFLAYOUT * layout; U16 numchars; U16 maxascii; // highest mapped ascii value - + U8 style; U8 encoding; @@ -553,15 +561,22 @@ int swf_FontEnumerate(SWF * swf,void (*FontCallback) (void*,U16,U8*), void*self) int swf_FontExtract(SWF * swf,int id,SWFFONT ** f); // Fetches all available information from DefineFont, DefineFontInfo, DefineText, ... // id = FontID, id=0 -> Extract first Font +int swf_FontExtract_DefineFont2(int id, SWFFONT * font, TAG * tag); +int swf_FontExtract_DefineFontInfo(int id, SWFFONT * f, TAG * t); +int swf_FontExtract_DefineFont(int id, SWFFONT * f, TAG * t); +int swf_FontExtract_GlyphNames(int id, SWFFONT * f, TAG * tag); int swf_FontIsItalic(SWFFONT * f); int swf_FontIsBold(SWFFONT * f); int swf_FontSetID(SWFFONT * f,U16 id); int swf_FontReduce(SWFFONT * f); +int swf_FontReduce_swfc(SWFFONT * f); int swf_FontInitUsage(SWFFONT * f); int swf_FontUseGlyph(SWFFONT * f, int glyph); +int swf_FontUseAll(SWFFONT* f); +int swf_FontUseUTF8(SWFFONT * f, U8 * s); int swf_FontUse(SWFFONT* f,U8 * s); int swf_FontSetDefine(TAG * t,SWFFONT * f); @@ -591,7 +606,7 @@ int swf_TextPrintDefineText(TAG * t,SWFFONT * f); void swf_FontPrepareForEditText(SWFFONT * f); /* notice: if you set the fontid, make sure you call swf_FontPrepareForEditText() for the font first */ -void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, +void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, int maxlength, U16 font, U16 height, EditTextLayout*layout, char*variable); SRECT swf_SetDefineText(TAG*tag, SWFFONT*font, RGBA*rgb, char*text, int scale); @@ -610,7 +625,7 @@ void swf_SetLoadFontParameters(int scale, int skip_unused, int full_unicode); void swf_DumpHeader(FILE * f,SWF * swf); void swf_DumpMatrix(FILE * f,MATRIX * m); -void swf_DumpTag(FILE * f,TAG * t); +void swf_DumpTag(FILE * f,TAG * t); void swf_DumpSWF(FILE * f,SWF*swf); void swf_DumpGradient(FILE* f, GRADIENT*gradient); char* swf_TagGetName(TAG*tag); @@ -627,7 +642,7 @@ void swf_DumpFont(SWFFONT * font); // Button Conditions -/* missing: IDLE_OUTDOWN +/* missing: IDLE_OUTDOWN OUTDOWN_OVERUP OVERUP_OUTDOWN */ @@ -674,9 +689,9 @@ void swf_DumpFont(SWFFONT * font); /* everything above 0x4000 is standard ascii: 0x4000 ' ' 0x4200 '!' 0x4600 '#' 0x4800 '$' 0x4a00 '%' 0x4c00 '&' ... - 0x6000 '0' ... 0x7200 '9' - 0x8000 '@' - 0x8200 'A' ... 0xb400 'Z' + 0x6000 '0' ... 0x7200 '9' + 0x8000 '@' + 0x8200 'A' ... 0xb400 'Z' ... 0xfc00 '~' */ @@ -776,7 +791,7 @@ void swf_uncgi(); // same behaviour as Steven Grimm's uncgi-library // swfaction.c -typedef struct _ActionTAG +typedef struct _ActionTAG { U8 op; U16 len; U8 * data; @@ -878,7 +893,7 @@ ActionTAG* action_BitLShift(ActionTAG*atag); ActionTAG* action_BitRShift(ActionTAG*atag); ActionTAG* action_BitURShift(ActionTAG*atag); ActionTAG* action_GotoFrame(ActionTAG*atag, U16 frame); -ActionTAG* action_GetUrl(ActionTAG*atag, char* url, char* label); +ActionTAG* action_GetUrl(ActionTAG*atag, const char* url, char* label); ActionTAG* action_StoreRegister(ActionTAG*atag, U8 reg); ActionTAG* action_Constantpool(ActionTAG*atag, char* constantpool); ActionTAG* action_WaitForFrame(ActionTAG*atag, U16 frame, U8 skip); @@ -886,7 +901,7 @@ ActionTAG* action_SetTarget(ActionTAG*atag, char* target); ActionTAG* action_GotoLabel(ActionTAG*atag, char* label); ActionTAG* action_WaitForFrame2(ActionTAG*atag, U8 skip); ActionTAG* action_With(ActionTAG*atag, char*object); -ActionTAG* action_PushString(ActionTAG*atag, char*str); +ActionTAG* action_PushString(ActionTAG*atag, const char*str); ActionTAG* action_PushFloat(ActionTAG*atag, float f); ActionTAG* action_PushNULL(ActionTAG*atag); ActionTAG* action_PushRegister(ActionTAG*atag, U8 reg); @@ -967,7 +982,7 @@ void swf_VideoStreamClear(VIDEOSTREAM*stream); // swfrender.c -typedef struct RENDERBUF +typedef struct RENDERBUF { int width; int height; @@ -981,7 +996,7 @@ 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_RenderSWF(RENDERBUF*buf, SWF*swf); -void swf_Render_AddImage(RENDERBUF*buf, U16 id, RGBA*img, int width, int height); +void swf_Render_AddImage(RENDERBUF*buf, U16 id, RGBA*img, int width, int height); /* img is non-premultiplied */ void swf_Render_ClearCanvas(RENDERBUF*dest); void swf_Render_Delete(RENDERBUF*dest); @@ -995,7 +1010,7 @@ void swf_Render_Delete(RENDERBUF*dest); #define FILTERTYPE_CONVOLUTION 5 #define FILTERTYPE_COLORMATRIX 6 #define FILTERTYPE_GRADIENTBEVEL 7 - + extern char*filtername[]; typedef struct _FILTER_GRADIENTGLOW { @@ -1054,9 +1069,10 @@ void swf_SetFilter(TAG*tag, FILTER*f); FILTER*swf_GetFilter(TAG*tag); FILTER*swf_NewFilter(U8 type); +void AVM2_InsertStops(SWF*swf); + #ifdef __cplusplus } #endif #endif -