From: boehme Date: Thu, 1 Nov 2001 16:42:01 +0000 (+0000) Subject: Forgot DOS2UNIX ... X-Git-Tag: release-0-1-0~15 X-Git-Url: http://git.asbjorn.it/?a=commitdiff_plain;h=f9916185439191347c40f4fc41ace0a20ac70018;p=swftools.git Forgot DOS2UNIX ... --- diff --git a/lib/modules/swfbutton.c b/lib/modules/swfbutton.c index 84528a4..6a4ba43 100644 --- a/lib/modules/swfbutton.c +++ b/lib/modules/swfbutton.c @@ -1,92 +1,92 @@ -/* swfbutton.c - - Button functions - - Extension module for the rfxswf library. - Part of the swftools package. - - Copyright (c) 2000, 2001 Rainer Böhme - - This file is distributed under the GPL, see file COPYING for details - -*/ - -int swf_ButtonSetRecord(TAG * t,U8 state,U16 id,U16 layer,MATRIX * m,CXFORM * cx) - -{ swf_SetU8(t,state); - swf_SetU16(t,id); - swf_SetU16(t,layer); - swf_SetMatrix(t,m); - if (swf_GetTagID(t)==ST_DEFINEBUTTON2) swf_SetCXForm(t,cx,0); - return 0; -} - -int swf_ButtonSetCondition(TAG * t,U16 condition) -{ swf_SetU16(t,0); // dummy for Action Offset -> later set by ButtonPostProcess - swf_SetU16(t,condition); - return 0; -} - -int swf_ButtonSetFlags(TAG * t,U8 flags) -{ if (swf_GetTagID(t)==ST_DEFINEBUTTON2) - { swf_SetU8(t,flags); - swf_SetU16(t,0); // dummy for Action Offset -> later set by ButtonPostProcess - } - return 0; -} - -void swf_SetButtonOffset(TAG * t,U32 offsetpos) -{ U32 now = swf_GetTagPos(t); - U16 diff = now-offsetpos; - swf_SetTagPos(t,offsetpos); - t->data[t->pos++] = (U8)(diff&0xff); - t->data[t->pos++] = (U8)(diff>>8); - swf_SetTagPos(t,now); -} - -int swf_ButtonPostProcess(TAG * t,int anz_action) -{ if (swf_GetTagID(t)==ST_DEFINEBUTTON2) - { U32 oldTagPos; - U32 offsetpos; - - oldTagPos = swf_GetTagPos(t); - - // scan DefineButton2 Record - - swf_GetU16(t); // Character ID - swf_GetU8(t); // Flags; - - offsetpos = swf_GetTagPos(t); // first offset - swf_GetU16(t); - - while (swf_GetU8(t)) // state -> parse ButtonRecord - { swf_GetU16(t); // id - swf_GetU16(t); // layer - swf_GetMatrix(t,NULL); // matrix - swf_GetCXForm(t,NULL,0);// CXForm - } - - swf_SetButtonOffset(t,offsetpos); - - while(anz_action) - { U8 a; - - offsetpos = swf_GetTagPos(t); // offset - swf_GetU16(t); - - swf_GetU16(t); // condition - - while (a=swf_GetU8(t)) // skip action records - { if (a&0x80) - { U16 l = swf_GetU16(t); - swf_GetBlock(t,NULL,l); - } - } - - if (--anz_action) swf_SetButtonOffset(t,offsetpos); - } - - swf_SetTagPos(t,oldTagPos); - } - return 0; -} +/* swfbutton.c + + Button functions + + Extension module for the rfxswf library. + Part of the swftools package. + + Copyright (c) 2000, 2001 Rainer Böhme + + This file is distributed under the GPL, see file COPYING for details + +*/ + +int swf_ButtonSetRecord(TAG * t,U8 state,U16 id,U16 layer,MATRIX * m,CXFORM * cx) + +{ swf_SetU8(t,state); + swf_SetU16(t,id); + swf_SetU16(t,layer); + swf_SetMatrix(t,m); + if (swf_GetTagID(t)==ST_DEFINEBUTTON2) swf_SetCXForm(t,cx,0); + return 0; +} + +int swf_ButtonSetCondition(TAG * t,U16 condition) +{ swf_SetU16(t,0); // dummy for Action Offset -> later set by ButtonPostProcess + swf_SetU16(t,condition); + return 0; +} + +int swf_ButtonSetFlags(TAG * t,U8 flags) +{ if (swf_GetTagID(t)==ST_DEFINEBUTTON2) + { swf_SetU8(t,flags); + swf_SetU16(t,0); // dummy for Action Offset -> later set by ButtonPostProcess + } + return 0; +} + +void swf_SetButtonOffset(TAG * t,U32 offsetpos) +{ U32 now = swf_GetTagPos(t); + U16 diff = now-offsetpos; + swf_SetTagPos(t,offsetpos); + t->data[t->pos++] = (U8)(diff&0xff); + t->data[t->pos++] = (U8)(diff>>8); + swf_SetTagPos(t,now); +} + +int swf_ButtonPostProcess(TAG * t,int anz_action) +{ if (swf_GetTagID(t)==ST_DEFINEBUTTON2) + { U32 oldTagPos; + U32 offsetpos; + + oldTagPos = swf_GetTagPos(t); + + // scan DefineButton2 Record + + swf_GetU16(t); // Character ID + swf_GetU8(t); // Flags; + + offsetpos = swf_GetTagPos(t); // first offset + swf_GetU16(t); + + while (swf_GetU8(t)) // state -> parse ButtonRecord + { swf_GetU16(t); // id + swf_GetU16(t); // layer + swf_GetMatrix(t,NULL); // matrix + swf_GetCXForm(t,NULL,0);// CXForm + } + + swf_SetButtonOffset(t,offsetpos); + + while(anz_action) + { U8 a; + + offsetpos = swf_GetTagPos(t); // offset + swf_GetU16(t); + + swf_GetU16(t); // condition + + while (a=swf_GetU8(t)) // skip action records + { if (a&0x80) + { U16 l = swf_GetU16(t); + swf_GetBlock(t,NULL,l); + } + } + + if (--anz_action) swf_SetButtonOffset(t,offsetpos); + } + + swf_SetTagPos(t,oldTagPos); + } + return 0; +}