X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Frfxswf.c;h=a6071c4fd4ffe538887d21ea4a96cf22ba24fe2a;hb=072be5204983fd801b1d573f5a8efc6e0ae2bc5a;hp=0abd61ac1cb67f75b825b8e681188a07316f64b8;hpb=c76b3f90fcf8511d3c1c37c9acd2b5a3ebc18cb8;p=swftools.git diff --git a/lib/rfxswf.c b/lib/rfxswf.c index 0abd61a..a6071c4 100644 --- a/lib/rfxswf.c +++ b/lib/rfxswf.c @@ -268,8 +268,9 @@ double swf_GetFixed(TAG * t) } void swf_SetFixed(TAG * t, double f) { - swf_SetU16(t, (U16)((f-(int)f)*65536)); - swf_SetU16(t, (U16)f); + U16 fr = (f-(int)f)*65536; + swf_SetU16(t, fr); + swf_SetU16(t, (U16)f - (f<0 && fr!=0)); } float swf_GetFixed8(TAG * t) { @@ -279,8 +280,9 @@ float swf_GetFixed8(TAG * t) } void swf_SetFixed8(TAG * t, float f) { - swf_SetU8(t, (U8)((f-(int)f)*256)); - swf_SetU8(t, (U8)f); + U8 fr = (f-(int)f)*256; + swf_SetU8(t, fr); + swf_SetU8(t, (U8)f - (f<0 && fr!=0)); } int swf_SetRGB(TAG * t,RGBA * col) @@ -1309,7 +1311,7 @@ int swf_WriteSWF2(writer_t*writer, SWF * swf) // Writes SWF to file, return } } - if(swf->fileVersion >= 8) { + if(swf->fileVersion >= 9) { if (swf->firstTag && swf->firstTag->id != ST_FILEATTRIBUTES) { U32 flags = 0x8; // | 128 = usenetwork, | 8 = hasmetadata