X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Frfxswf.h;h=c9bdc9ebf48dfd4b7c9d765df5ba54fe18533868;hb=898ceddb63e8fb4bd04cc8a87e0b93b6def552e1;hp=d64664a10fc3cc026e1ff58256be4aaf7f4537c9;hpb=1dddda0e549c7b754cdb152c702cfe7103ccbbf3;p=swftools.git diff --git a/lib/rfxswf.h b/lib/rfxswf.h index d64664a..c9bdc9e 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -119,6 +119,8 @@ typedef struct _CXFORM S16 b0, b1; } CXFORM, * LPCXFORM; +#define GRADIENT_LINEAR 0x10 +#define GRADIENT_RADIAL 0x12 typedef struct _GRADIENT { int num; @@ -236,17 +238,20 @@ int swf_SetU8(TAG * t,U8 v); // resets Bitcount int swf_SetU16(TAG * t,U16 v); int swf_SetU32(TAG * t,U32 v); -int swf_GetPoint(TAG * t,SPOINT * p); // resets Bitcount +//int swf_GetPoint(TAG * t,SPOINT * p); // resets Bitcount int swf_GetRect(TAG * t,SRECT * r); int swf_GetMatrix(TAG * t,MATRIX * m); int swf_GetCXForm(TAG * t,CXFORM * cx,U8 alpha); -int swf_SetPoint(TAG * t,SPOINT * p); // resets Bitcount +//int swf_SetPoint(TAG * t,SPOINT * p); // resets Bitcount int swf_SetRect(TAG * t,SRECT * r); int swf_SetMatrix(TAG * t,MATRIX * m); int swf_SetCXForm(TAG * t,CXFORM * cx,U8 alpha); int swf_SetRGB(TAG * t,RGBA * col); int swf_SetRGBA(TAG * t,RGBA * col); +void swf_SetPassword(TAG * t, const char * password); + +int swf_VerifyPassword(TAG * t, const char * password); // helper functions: @@ -350,7 +355,7 @@ typedef struct _FILLSTYLE RGBA color; MATRIX m; U16 id_bitmap; - GRADIENT* gradient; + GRADIENT gradient; } FILLSTYLE, * LPFILLSTYLE; typedef struct _SHAPE // NEVER access a Shape-Struct directly ! @@ -409,6 +414,7 @@ int swf_SetSimpleShape(TAG * t,SHAPE * s); // without Linestyle/Fillstyle Re int swf_ShapeAddLineStyle(SHAPE * s,U16 width,RGBA * color); int swf_ShapeAddSolidFillStyle(SHAPE * s,RGBA * color); int swf_ShapeAddBitmapFillStyle(SHAPE * s,MATRIX * m,U16 id_bitmap,int clip); +int swf_ShapeAddGradientFillStyle(SHAPE * s,MATRIX * m,GRADIENT* gradient,int radial); int swf_SetShapeStyles(TAG * t,SHAPE * s); int swf_ShapeCountBits(SHAPE * s,U8 * fbits,U8 * lbits); @@ -432,6 +438,7 @@ void swf_Shape2ToShape(SHAPE2*shape2, SHAPE*shape); SRECT swf_GetShapeBoundingBox(SHAPE2*shape); void swf_SetShape2(TAG*tag, SHAPE2*shape); void swf_Shape2Free(SHAPE2 * s); +void swf_DumpShape(SHAPE2*shape2); // swfdraw.c @@ -446,14 +453,22 @@ typedef struct _SWFSHAPEDRAWER SHAPE*shape; TAG*tag; int tagfree; + int lastx; + int lasty; + SRECT bbox; + char isfinished; } SWFSHAPEDRAWER; -void swf_DrawerInit(SWFSHAPEDRAWER*draw); +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); // swffont.c @@ -582,6 +597,8 @@ 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); + // swfdump.c void swf_DumpHeader(FILE * f,SWF * swf);