From: kramm Date: Sun, 16 Dec 2001 19:27:20 +0000 (+0000) Subject: added EditText handling. X-Git-Tag: release-0-2-2~91 X-Git-Url: http://git.asbjorn.biz/?p=swftools.git;a=commitdiff_plain;h=72805733f31429734c88836c2e77ba55cb90ae84 added EditText handling. --- diff --git a/lib/modules/swftext.c b/lib/modules/swftext.c index 80fa15f..d05b84f 100644 --- a/lib/modules/swftext.c +++ b/lib/modules/swftext.c @@ -842,3 +842,40 @@ void swf_WriteFont(SWFFONT*font, char* filename) } +void swf_SetEditText(TAG*tag, U16 flags, SRECT r, char*text, RGBA*color, + int maxlength, U16 font, U16 height, EditTextLayout*layout, char*variable) +{ + swf_SetRect(tag,&r); + swf_ResetWriteBits(tag); + + flags &= ~(ET_HASTEXT|ET_HASTEXTCOLOR|ET_HASMAXLENGTH|ET_HASFONT|ET_HASLAYOUT); + if(text) flags |= ET_HASTEXT; + if(color) flags |= ET_HASTEXTCOLOR; + if(maxlength) flags |= ET_HASMAXLENGTH; + if(font) flags |= ET_HASFONT; + if(layout) flags |= ET_HASLAYOUT; + + swf_SetBits(tag, flags, 16); + + if(flags & ET_HASFONT) { + swf_SetU16(tag, font); //font + swf_SetU16(tag, height); //fontheight + } + if(flags & ET_HASTEXTCOLOR) { + swf_SetRGBA(tag, color); + } + if(flags & ET_HASMAXLENGTH) { + swf_SetU16(tag, maxlength); //maxlength + } + if(flags & ET_HASLAYOUT) { + swf_SetU8(tag,layout->align); //align + swf_SetU16(tag,layout->leftmargin); //left margin + swf_SetU16(tag,layout->rightmargin); //right margin + swf_SetU16(tag,layout->indent); //indent + swf_SetU16(tag,layout->leading); //leading + } + swf_SetString(tag, variable); + if(flags & ET_HASTEXT) + swf_SetString(tag,text); +} + diff --git a/lib/rfxswf.h b/lib/rfxswf.h index 81ccf9f..985be86 100644 --- a/lib/rfxswf.h +++ b/lib/rfxswf.h @@ -355,6 +355,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 @@ -395,6 +421,9 @@ 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 +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);