X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Fpng2swf.c;h=d3247d8d263090954a67fd5a0c44b3336c1e9805;hb=f03de7ce28ee2c39fdb9f658359359429135c862;hp=927504e16982354206fe05dbe2bf2ae919eafe81;hpb=ce77200a441ffa9ba65aee4308ba32daf014f74d;p=swftools.git diff --git a/src/png2swf.c b/src/png2swf.c index 927504e..d3247d8 100644 --- a/src/png2swf.c +++ b/src/png2swf.c @@ -42,7 +42,7 @@ TAG *MovieStart(SWF * swf, int framerate, int dx, int dy) memset(swf, 0x00, sizeof(SWF)); - swf->fileVersion = 4; + swf->fileVersion = 5; swf->frameRate = (25600 / framerate); swf->movieSize.xmax = dx * 20; swf->movieSize.ymax = dy * 20; @@ -50,6 +50,7 @@ TAG *MovieStart(SWF * swf, int framerate, int dx, int dy) t = swf->firstTag = swf_InsertTag(NULL, ST_SETBACKGROUNDCOLOR); rgb.r = rgb.g = rgb.b = rgb.a = 0x00; + //rgb.g = 0xff; <--- handy for testing alpha conversion swf_SetRGB(t, &rgb); return t; @@ -65,7 +66,7 @@ int MovieFinish(SWF * swf, TAG * t, char *sname) else { if (!sname) sname = "output.swf"; - handle = open(sname, O_RDWR | O_CREAT | O_TRUNC, 0666); + handle = open(sname, O_BINARY | O_RDWR | O_CREAT | O_TRUNC, 0666); } if FAILED (swf_WriteSWF(handle, swf)) if (VERBOSE(1)) @@ -348,7 +349,7 @@ void applyfilter4(int mode, U8*src, U8*old, U8*dest, int width) lastr = dest[1]; lastg = dest[2]; lastb = dest[3]; - upperlastr = old[0]; + upperlasta = old[0]; upperlastr = old[1]; upperlastg = old[2]; upperlastb = old[3]; @@ -511,6 +512,8 @@ TAG *MovieAddFrame(SWF * swf, TAG * t, char *sname, int id) int i,s=0; int x,y; int pos=0; + int opaque=0; + int transparent=0; /* in case for mode 2, the following also performs 24->32 bit conversion */ for(y=0;yid = ST_DEFINEBITSJPEG3; + } + else +#endif + { + swf_SetLosslessBits(t, header.width, header.height, data2, BMF_32BIT); + } free(data2); } else { @@ -610,7 +643,7 @@ TAG *MovieAddFrame(SWF * swf, TAG * t, char *sname, int id) free(data2); } - t = swf_InsertTag(t, ST_DEFINESHAPE); + t = swf_InsertTag(t, ST_DEFINESHAPE3); swf_ShapeNew(&s); swf_GetMatrix(NULL, &m); @@ -636,14 +669,14 @@ TAG *MovieAddFrame(SWF * swf, TAG * t, char *sname, int id) swf_ShapeSetEnd(t); t = swf_InsertTag(t, ST_REMOVEOBJECT2); - swf_SetU16(t, 1); // depth + swf_SetU16(t, 50); // depth t = swf_InsertTag(t, ST_PLACEOBJECT2); swf_GetMatrix(NULL, &m); m.tx = (swf->movieSize.xmax - (int) header.width * 20) / 2; m.ty = (swf->movieSize.ymax - (int) header.height * 20) / 2; - swf_ObjectPlace(t, id + 1, 1, &m, NULL, NULL); + swf_ObjectPlace(t, id + 1, 50, &m, NULL, NULL); t = swf_InsertTag(t, ST_SHOWFRAME);