mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-26 00:58:12 +00:00
Fix the "64 colors flx too dark" bug.
Original commit message from CVS: Fix the "64 colors flx too dark" bug.
This commit is contained in:
parent
5c28518728
commit
f34f00f438
3 changed files with 32 additions and 15 deletions
|
@ -66,7 +66,7 @@ flx_colorspace_convert(FlxColorSpaceConverter *flxpal, guchar *src, guchar *dest
|
||||||
|
|
||||||
|
|
||||||
void
|
void
|
||||||
flx_set_palette_vector(FlxColorSpaceConverter *flxpal, guint start, guint num, guchar *newpal)
|
flx_set_palette_vector(FlxColorSpaceConverter *flxpal, guint start, guint num, guchar *newpal, gint scale)
|
||||||
{
|
{
|
||||||
guint grab;
|
guint grab;
|
||||||
|
|
||||||
|
@ -75,20 +75,33 @@ flx_set_palette_vector(FlxColorSpaceConverter *flxpal, guint start, guint num, g
|
||||||
|
|
||||||
grab = ((start + num) > 0x100 ? 0x100 - start : num);
|
grab = ((start + num) > 0x100 ? 0x100 - start : num);
|
||||||
|
|
||||||
memcpy(&flxpal->palvec[start * 3], newpal, grab*3);
|
if (scale) {
|
||||||
|
gint i = 0;
|
||||||
|
|
||||||
|
start *= 3;
|
||||||
|
while (grab) {
|
||||||
|
flxpal->palvec[start++] = newpal[i++] << scale;
|
||||||
|
flxpal->palvec[start++] = newpal[i++] << scale;
|
||||||
|
flxpal->palvec[start++] = newpal[i++] << scale;
|
||||||
|
grab--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
memcpy(&flxpal->palvec[start * 3], newpal, grab * 3);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
flx_set_color(FlxColorSpaceConverter *flxpal, guint colr, guint red, guint green, guint blue)
|
flx_set_color(FlxColorSpaceConverter *flxpal, guint colr, guint red, guint green, guint blue, gint scale)
|
||||||
{
|
{
|
||||||
|
|
||||||
g_return_if_fail(flxpal != NULL);
|
g_return_if_fail(flxpal != NULL);
|
||||||
g_return_if_fail(colr < 0x100);
|
g_return_if_fail(colr < 0x100);
|
||||||
|
|
||||||
flxpal->palvec[(colr * 3)] = red;
|
flxpal->palvec[(colr * 3)] = red << scale;
|
||||||
flxpal->palvec[(colr * 3) + 1] = green;
|
flxpal->palvec[(colr * 3) + 1] = green << scale;
|
||||||
flxpal->palvec[(colr * 3) + 2] = blue;
|
flxpal->palvec[(colr * 3) + 2] = blue << scale;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -37,7 +37,7 @@ void flx_colorspace_convert(FlxColorSpaceConverter *flxpal, guchar *src, guchar
|
||||||
FlxColorSpaceConverter * flx_colorspace_converter_new(gint width, gint height);
|
FlxColorSpaceConverter * flx_colorspace_converter_new(gint width, gint height);
|
||||||
|
|
||||||
void flx_set_palette_vector(FlxColorSpaceConverter *flxpal, guint start, guint num,
|
void flx_set_palette_vector(FlxColorSpaceConverter *flxpal, guint start, guint num,
|
||||||
guchar *newpal);
|
guchar *newpal, gint scale);
|
||||||
void flx_set_color(FlxColorSpaceConverter *flxpal, guint colr, guint red, guint green,
|
void flx_set_color(FlxColorSpaceConverter *flxpal, guint colr, guint red, guint green,
|
||||||
guint blue);
|
guint blue, gint scale);
|
||||||
|
|
||||||
|
|
|
@ -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 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_color (GstFlxDec *, guchar *, guchar *, gint);
|
||||||
static void flx_decode_brun(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_fli (GstFlxDec *, guchar *, guchar *);
|
||||||
static void flx_decode_delta_flc(GstFlxDec *, guchar *, guchar *);
|
static void flx_decode_delta_flc (GstFlxDec *, guchar *, guchar *);
|
||||||
|
|
||||||
#define rndalign(off) ((off) + ((off) % 2))
|
#define rndalign(off) ((off) + ((off) % 2))
|
||||||
|
|
||||||
|
@ -200,8 +200,12 @@ flx_decode_chunks (GstFlxDec *flxdec , gulong count, gchar *data, gchar *dest)
|
||||||
switch(hdr->id)
|
switch(hdr->id)
|
||||||
{
|
{
|
||||||
case FLX_COLOR64:
|
case FLX_COLOR64:
|
||||||
|
flx_decode_color(flxdec, data, dest, 2);
|
||||||
|
data += rndalign(hdr->size) - FlxFrameChunkSize;
|
||||||
|
break;
|
||||||
|
|
||||||
case FLX_COLOR256:
|
case FLX_COLOR256:
|
||||||
flx_decode_color(flxdec, data, dest);
|
flx_decode_color(flxdec, data, dest, 0);
|
||||||
data += rndalign(hdr->size) - FlxFrameChunkSize;
|
data += rndalign(hdr->size) - FlxFrameChunkSize;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -240,7 +244,7 @@ flx_decode_chunks (GstFlxDec *flxdec , gulong count, gchar *data, gchar *dest)
|
||||||
|
|
||||||
|
|
||||||
static void
|
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;
|
guint packs, count, indx;
|
||||||
|
|
||||||
|
@ -262,7 +266,7 @@ flx_decode_color(GstFlxDec *flxdec, guchar *data, guchar *dest)
|
||||||
count = 256;
|
count = 256;
|
||||||
|
|
||||||
g_print("GstFlxDec: cmap count: %d (indx: %d)\n", count, indx);
|
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);
|
data += (count * 3);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue