diff options
author | Wim Taymans <wim.taymans@gmail.com> | 2002-01-18 18:41:58 +0000 |
---|---|---|
committer | Wim Taymans <wim.taymans@gmail.com> | 2002-01-18 18:41:58 +0000 |
commit | 35e1987b602486028573eb697d68e5ce3c3f46bc (patch) | |
tree | 6efd8a8014417b956f5c8148a0e0b04d8eab506a /gst/flx/gstflxdec.c | |
parent | 272ae0efe3234d2274abe7669957faf00035949d (diff) | |
download | gst-plugins-bad-35e1987b602486028573eb697d68e5ce3c3f46bc.tar.gz gst-plugins-bad-35e1987b602486028573eb697d68e5ce3c3f46bc.tar.bz2 gst-plugins-bad-35e1987b602486028573eb697d68e5ce3c3f46bc.zip |
Fix the "64 colors flx too dark" bug.
Original commit message from CVS:
Fix the "64 colors flx too dark" bug.
Diffstat (limited to 'gst/flx/gstflxdec.c')
-rw-r--r-- | gst/flx/gstflxdec.c | 18 |
1 files changed, 11 insertions, 7 deletions
diff --git a/gst/flx/gstflxdec.c b/gst/flx/gstflxdec.c index 95e55cc6..b679fa48 100644 --- a/gst/flx/gstflxdec.c +++ b/gst/flx/gstflxdec.c @@ -98,10 +98,10 @@ static void gst_flxdec_set_property (GObject *object, guint prop_id, const GValu static void gst_flxdec_get_property (GObject *object, guint prop_id, GValue *value, GParamSpec *pspec); -static void flx_decode_color(GstFlxDec *, guchar *, guchar *); -static void flx_decode_brun(GstFlxDec *, guchar *, guchar *); -static void flx_decode_delta_fli(GstFlxDec *, guchar *, guchar *); -static void flx_decode_delta_flc(GstFlxDec *, guchar *, guchar *); +static void flx_decode_color (GstFlxDec *, guchar *, guchar *, gint); +static void flx_decode_brun (GstFlxDec *, guchar *, guchar *); +static void flx_decode_delta_fli (GstFlxDec *, guchar *, guchar *); +static void flx_decode_delta_flc (GstFlxDec *, guchar *, guchar *); #define rndalign(off) ((off) + ((off) % 2)) @@ -200,8 +200,12 @@ flx_decode_chunks (GstFlxDec *flxdec , gulong count, gchar *data, gchar *dest) switch(hdr->id) { case FLX_COLOR64: + flx_decode_color(flxdec, data, dest, 2); + data += rndalign(hdr->size) - FlxFrameChunkSize; + break; + case FLX_COLOR256: - flx_decode_color(flxdec, data, dest); + flx_decode_color(flxdec, data, dest, 0); data += rndalign(hdr->size) - FlxFrameChunkSize; break; @@ -240,7 +244,7 @@ flx_decode_chunks (GstFlxDec *flxdec , gulong count, gchar *data, gchar *dest) static void -flx_decode_color(GstFlxDec *flxdec, guchar *data, guchar *dest) +flx_decode_color(GstFlxDec *flxdec, guchar *data, guchar *dest, gint scale) { guint packs, count, indx; @@ -262,7 +266,7 @@ flx_decode_color(GstFlxDec *flxdec, guchar *data, guchar *dest) count = 256; g_print("GstFlxDec: cmap count: %d (indx: %d)\n", count, indx); - flx_set_palette_vector(flxdec->converter, indx, count, data); + flx_set_palette_vector(flxdec->converter, indx, count, data, scale); data += (count * 3); } |