parent
04291bf0ab
commit
e94720fea0
|
@ -46,31 +46,31 @@
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/*--------------------------------------------------------
|
/*--------------------------------------------------------
|
||||||
Matrix für sYCC, Amendment 1 to IEC 61966-2-1
|
Matrix for sYCC, Amendment 1 to IEC 61966-2-1
|
||||||
|
|
||||||
Y : 0.299 0.587 0.114 :R
|
Y : 0.299 0.587 0.114 :R
|
||||||
Cb: -0.1687 -0.3312 0.5 :G
|
Cb: -0.1687 -0.3312 0.5 :G
|
||||||
Cr: 0.5 -0.4187 -0.0812 :B
|
Cr: 0.5 -0.4187 -0.0812 :B
|
||||||
|
|
||||||
Inverse:
|
Inverse:
|
||||||
|
|
||||||
R: 1 -3.68213e-05 1.40199 :Y
|
R: 1 -3.68213e-05 1.40199 :Y
|
||||||
G: 1.00003 -0.344125 -0.714128 :Cb - 2^(prec - 1)
|
G: 1.00003 -0.344125 -0.714128 :Cb - 2^(prec - 1)
|
||||||
B: 0.999823 1.77204 -8.04142e-06 :Cr - 2^(prec - 1)
|
B: 0.999823 1.77204 -8.04142e-06 :Cr - 2^(prec - 1)
|
||||||
|
|
||||||
-----------------------------------------------------------*/
|
-----------------------------------------------------------*/
|
||||||
static void sycc_to_rgb(int offset, int upb, int y, int cb, int cr,
|
static void sycc_to_rgb(int offset, int upb, int y, int cb, int cr,
|
||||||
int *out_r, int *out_g, int *out_b)
|
int *out_r, int *out_g, int *out_b)
|
||||||
{
|
{
|
||||||
int r, g, b;
|
int r, g, b;
|
||||||
|
|
||||||
cb -= offset; cr -= offset;
|
cb -= offset; cr -= offset;
|
||||||
r = y + (int)(1.402 * (float)cr);
|
r = y + (int)(1.402 * (float)cr);
|
||||||
if(r < 0) r = 0; else if(r > upb) r = upb; *out_r = r;
|
if(r < 0) r = 0; else if(r > upb) r = upb; *out_r = r;
|
||||||
|
|
||||||
g = y - (int)(0.344 * (float)cb + 0.714 * (float)cr);
|
g = y - (int)(0.344 * (float)cb + 0.714 * (float)cr);
|
||||||
if(g < 0) g = 0; else if(g > upb) g = upb; *out_g = g;
|
if(g < 0) g = 0; else if(g > upb) g = upb; *out_g = g;
|
||||||
|
|
||||||
b = y + (int)(1.772 * (float)cb);
|
b = y + (int)(1.772 * (float)cb);
|
||||||
if(b < 0) b = 0; else if(b > upb) b = upb; *out_b = b;
|
if(b < 0) b = 0; else if(b > upb) b = upb; *out_b = b;
|
||||||
}
|
}
|
||||||
|
@ -79,185 +79,206 @@ static void sycc444_to_rgb(opj_image_t *img)
|
||||||
{
|
{
|
||||||
int *d0, *d1, *d2, *r, *g, *b;
|
int *d0, *d1, *d2, *r, *g, *b;
|
||||||
const int *y, *cb, *cr;
|
const int *y, *cb, *cr;
|
||||||
int maxw, maxh, max, i, offset, upb;
|
unsigned int maxw, maxh, max, i;
|
||||||
|
int offset, upb;
|
||||||
i = img->comps[0].prec;
|
|
||||||
offset = 1<<(i - 1); upb = (1<<i)-1;
|
upb = (int)img->comps[0].prec;
|
||||||
|
offset = 1<<(upb - 1); upb = (1<<upb)-1;
|
||||||
maxw = img->comps[0].w; maxh = img->comps[0].h;
|
|
||||||
|
maxw = (unsigned int)img->comps[0].w; maxh = (unsigned int)img->comps[0].h;
|
||||||
max = maxw * maxh;
|
max = maxw * maxh;
|
||||||
|
|
||||||
y = img->comps[0].data;
|
y = img->comps[0].data;
|
||||||
cb = img->comps[1].data;
|
cb = img->comps[1].data;
|
||||||
cr = img->comps[2].data;
|
cr = img->comps[2].data;
|
||||||
|
|
||||||
d0 = r = (int*)malloc(sizeof(int) * max);
|
d0 = r = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d1 = g = (int*)malloc(sizeof(int) * max);
|
d1 = g = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d2 = b = (int*)malloc(sizeof(int) * max);
|
d2 = b = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
|
|
||||||
for(i = 0; i < max; ++i)
|
for(i = 0U; i < max; ++i)
|
||||||
{
|
{
|
||||||
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++cb; ++cr; ++r; ++g; ++b;
|
||||||
++y; ++cb; ++cr; ++r; ++g; ++b;
|
}
|
||||||
}
|
|
||||||
free(img->comps[0].data); img->comps[0].data = d0;
|
free(img->comps[0].data); img->comps[0].data = d0;
|
||||||
free(img->comps[1].data); img->comps[1].data = d1;
|
free(img->comps[1].data); img->comps[1].data = d1;
|
||||||
free(img->comps[2].data); img->comps[2].data = d2;
|
free(img->comps[2].data); img->comps[2].data = d2;
|
||||||
|
|
||||||
}/* sycc444_to_rgb() */
|
}/* sycc444_to_rgb() */
|
||||||
|
|
||||||
static void sycc422_to_rgb(opj_image_t *img)
|
static void sycc422_to_rgb(opj_image_t *img)
|
||||||
{
|
{
|
||||||
int *d0, *d1, *d2, *r, *g, *b;
|
int *d0, *d1, *d2, *r, *g, *b;
|
||||||
const int *y, *cb, *cr;
|
const int *y, *cb, *cr;
|
||||||
int maxw, maxh, max, offset, upb;
|
unsigned int maxw, maxh, max;
|
||||||
int i, j;
|
int offset, upb;
|
||||||
|
unsigned int i, j;
|
||||||
i = img->comps[0].prec;
|
|
||||||
offset = 1<<(i - 1); upb = (1<<i)-1;
|
upb = (int)img->comps[0].prec;
|
||||||
|
offset = 1<<(upb - 1); upb = (1<<upb)-1;
|
||||||
maxw = img->comps[0].w; maxh = img->comps[0].h;
|
|
||||||
|
maxw = (unsigned int)img->comps[0].w; maxh = (unsigned int)img->comps[0].h;
|
||||||
max = maxw * maxh;
|
max = maxw * maxh;
|
||||||
|
|
||||||
y = img->comps[0].data;
|
y = img->comps[0].data;
|
||||||
cb = img->comps[1].data;
|
cb = img->comps[1].data;
|
||||||
cr = img->comps[2].data;
|
cr = img->comps[2].data;
|
||||||
|
|
||||||
d0 = r = (int*)malloc(sizeof(int) * max);
|
d0 = r = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d1 = g = (int*)malloc(sizeof(int) * max);
|
d1 = g = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d2 = b = (int*)malloc(sizeof(int) * max);
|
d2 = b = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
|
|
||||||
for(i=0; i < maxh; ++i)
|
for(i=0U; i < maxh; ++i)
|
||||||
{
|
{
|
||||||
for(j=0; j < maxw; j += 2)
|
for(j=0U; j < (maxw & ~(unsigned int)1U); j += 2U)
|
||||||
{
|
{
|
||||||
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++r; ++g; ++b;
|
||||||
++y; ++r; ++g; ++b;
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++r; ++g; ++b; ++cb; ++cr;
|
||||||
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
}
|
||||||
|
if (j < maxw) {
|
||||||
++y; ++r; ++g; ++b; ++cb; ++cr;
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
}
|
++y; ++r; ++g; ++b; ++cb; ++cr;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
free(img->comps[0].data); img->comps[0].data = d0;
|
free(img->comps[0].data); img->comps[0].data = d0;
|
||||||
free(img->comps[1].data); img->comps[1].data = d1;
|
free(img->comps[1].data); img->comps[1].data = d1;
|
||||||
free(img->comps[2].data); img->comps[2].data = d2;
|
free(img->comps[2].data); img->comps[2].data = d2;
|
||||||
|
|
||||||
img->comps[1].w = maxw; img->comps[1].h = maxh;
|
img->comps[1].w = maxw; img->comps[1].h = maxh;
|
||||||
img->comps[2].w = maxw; img->comps[2].h = maxh;
|
img->comps[2].w = maxw; img->comps[2].h = maxh;
|
||||||
img->comps[1].dx = img->comps[0].dx;
|
img->comps[1].dx = img->comps[0].dx;
|
||||||
img->comps[2].dx = img->comps[0].dx;
|
img->comps[2].dx = img->comps[0].dx;
|
||||||
img->comps[1].dy = img->comps[0].dy;
|
img->comps[1].dy = img->comps[0].dy;
|
||||||
img->comps[2].dy = img->comps[0].dy;
|
img->comps[2].dy = img->comps[0].dy;
|
||||||
|
|
||||||
}/* sycc422_to_rgb() */
|
}/* sycc422_to_rgb() */
|
||||||
|
|
||||||
static void sycc420_to_rgb(opj_image_t *img)
|
static void sycc420_to_rgb(opj_image_t *img)
|
||||||
{
|
{
|
||||||
int *d0, *d1, *d2, *r, *g, *b, *nr, *ng, *nb;
|
int *d0, *d1, *d2, *r, *g, *b, *nr, *ng, *nb;
|
||||||
const int *y, *cb, *cr, *ny;
|
const int *y, *cb, *cr, *ny;
|
||||||
int maxw, maxh, max, offset, upb;
|
unsigned int maxw, maxh, max;
|
||||||
int i, j;
|
int offset, upb;
|
||||||
|
unsigned int i, j;
|
||||||
i = img->comps[0].prec;
|
|
||||||
offset = 1<<(i - 1); upb = (1<<i)-1;
|
upb = (int)img->comps[0].prec;
|
||||||
|
offset = 1<<(upb - 1); upb = (1<<upb)-1;
|
||||||
maxw = img->comps[0].w; maxh = img->comps[0].h;
|
|
||||||
|
maxw = (unsigned int)img->comps[0].w; maxh = (unsigned int)img->comps[0].h;
|
||||||
max = maxw * maxh;
|
max = maxw * maxh;
|
||||||
|
|
||||||
y = img->comps[0].data;
|
y = img->comps[0].data;
|
||||||
cb = img->comps[1].data;
|
cb = img->comps[1].data;
|
||||||
cr = img->comps[2].data;
|
cr = img->comps[2].data;
|
||||||
|
|
||||||
d0 = r = (int*)malloc(sizeof(int) * max);
|
d0 = r = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d1 = g = (int*)malloc(sizeof(int) * max);
|
d1 = g = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
d2 = b = (int*)malloc(sizeof(int) * max);
|
d2 = b = (int*)malloc(sizeof(int) * (size_t)max);
|
||||||
|
|
||||||
for(i=0; i < maxh; i += 2)
|
for(i=0U; i < (maxh & ~(unsigned int)1U); i += 2U)
|
||||||
{
|
{
|
||||||
ny = y + maxw;
|
ny = y + maxw;
|
||||||
nr = r + maxw; ng = g + maxw; nb = b + maxw;
|
nr = r + maxw; ng = g + maxw; nb = b + maxw;
|
||||||
|
|
||||||
for(j=0; j < maxw; j += 2)
|
for(j=0; j < (maxw & ~(unsigned int)1U); j += 2U)
|
||||||
{
|
{
|
||||||
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++r; ++g; ++b;
|
||||||
++y; ++r; ++g; ++b;
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++r; ++g; ++b;
|
||||||
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
|
||||||
|
sycc_to_rgb(offset, upb, *ny, *cb, *cr, nr, ng, nb);
|
||||||
++y; ++r; ++g; ++b;
|
++ny; ++nr; ++ng; ++nb;
|
||||||
|
sycc_to_rgb(offset, upb, *ny, *cb, *cr, nr, ng, nb);
|
||||||
sycc_to_rgb(offset, upb, *ny, *cb, *cr, nr, ng, nb);
|
++ny; ++nr; ++ng; ++nb; ++cb; ++cr;
|
||||||
|
}
|
||||||
++ny; ++nr; ++ng; ++nb;
|
if(j < maxw)
|
||||||
|
{
|
||||||
sycc_to_rgb(offset, upb, *ny, *cb, *cr, nr, ng, nb);
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
++y; ++r; ++g; ++b;
|
||||||
++ny; ++nr; ++ng; ++nb; ++cb; ++cr;
|
|
||||||
}
|
sycc_to_rgb(offset, upb, *ny, *cb, *cr, nr, ng, nb);
|
||||||
y += maxw; r += maxw; g += maxw; b += maxw;
|
++ny; ++nr; ++ng; ++nb; ++cb; ++cr;
|
||||||
}
|
}
|
||||||
|
y += maxw; r += maxw; g += maxw; b += maxw;
|
||||||
|
}
|
||||||
|
if(i < maxh)
|
||||||
|
{
|
||||||
|
for(j=0U; j < (maxw & ~(unsigned int)1U); j += 2U)
|
||||||
|
{
|
||||||
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
|
||||||
|
++y; ++r; ++g; ++b;
|
||||||
|
|
||||||
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
|
||||||
|
++y; ++r; ++g; ++b; ++cb; ++cr;
|
||||||
|
}
|
||||||
|
if(j < maxw)
|
||||||
|
{
|
||||||
|
sycc_to_rgb(offset, upb, *y, *cb, *cr, r, g, b);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
free(img->comps[0].data); img->comps[0].data = d0;
|
free(img->comps[0].data); img->comps[0].data = d0;
|
||||||
free(img->comps[1].data); img->comps[1].data = d1;
|
free(img->comps[1].data); img->comps[1].data = d1;
|
||||||
free(img->comps[2].data); img->comps[2].data = d2;
|
free(img->comps[2].data); img->comps[2].data = d2;
|
||||||
|
|
||||||
img->comps[1].w = maxw; img->comps[1].h = maxh;
|
img->comps[1].w = maxw; img->comps[1].h = maxh;
|
||||||
img->comps[2].w = maxw; img->comps[2].h = maxh;
|
img->comps[2].w = maxw; img->comps[2].h = maxh;
|
||||||
img->comps[1].dx = img->comps[0].dx;
|
img->comps[1].dx = img->comps[0].dx;
|
||||||
img->comps[2].dx = img->comps[0].dx;
|
img->comps[2].dx = img->comps[0].dx;
|
||||||
img->comps[1].dy = img->comps[0].dy;
|
img->comps[1].dy = img->comps[0].dy;
|
||||||
img->comps[2].dy = img->comps[0].dy;
|
img->comps[2].dy = img->comps[0].dy;
|
||||||
|
|
||||||
}/* sycc420_to_rgb() */
|
}/* sycc420_to_rgb() */
|
||||||
|
|
||||||
void color_sycc_to_rgb(opj_image_t *img)
|
void color_sycc_to_rgb(opj_image_t *img)
|
||||||
{
|
{
|
||||||
if(img->numcomps < 3)
|
if(img->numcomps < 3)
|
||||||
{
|
{
|
||||||
img->color_space = CLRSPC_GRAY;
|
img->color_space = CLRSPC_GRAY;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if((img->comps[0].dx == 1)
|
if((img->comps[0].dx == 1)
|
||||||
&& (img->comps[1].dx == 2)
|
&& (img->comps[1].dx == 2)
|
||||||
&& (img->comps[2].dx == 2)
|
&& (img->comps[2].dx == 2)
|
||||||
&& (img->comps[0].dy == 1)
|
&& (img->comps[0].dy == 1)
|
||||||
&& (img->comps[1].dy == 2)
|
&& (img->comps[1].dy == 2)
|
||||||
&& (img->comps[2].dy == 2))/* horizontal and vertical sub-sample */
|
&& (img->comps[2].dy == 2))/* horizontal and vertical sub-sample */
|
||||||
{
|
{
|
||||||
sycc420_to_rgb(img);
|
sycc420_to_rgb(img);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if((img->comps[0].dx == 1)
|
if((img->comps[0].dx == 1)
|
||||||
&& (img->comps[1].dx == 2)
|
&& (img->comps[1].dx == 2)
|
||||||
&& (img->comps[2].dx == 2)
|
&& (img->comps[2].dx == 2)
|
||||||
&& (img->comps[0].dy == 1)
|
&& (img->comps[0].dy == 1)
|
||||||
&& (img->comps[1].dy == 1)
|
&& (img->comps[1].dy == 1)
|
||||||
&& (img->comps[2].dy == 1))/* horizontal sub-sample only */
|
&& (img->comps[2].dy == 1))/* horizontal sub-sample only */
|
||||||
{
|
{
|
||||||
sycc422_to_rgb(img);
|
sycc422_to_rgb(img);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
if((img->comps[0].dx == 1)
|
if((img->comps[0].dx == 1)
|
||||||
&& (img->comps[1].dx == 1)
|
&& (img->comps[1].dx == 1)
|
||||||
&& (img->comps[2].dx == 1)
|
&& (img->comps[2].dx == 1)
|
||||||
&& (img->comps[0].dy == 1)
|
&& (img->comps[0].dy == 1)
|
||||||
&& (img->comps[1].dy == 1)
|
&& (img->comps[1].dy == 1)
|
||||||
&& (img->comps[2].dy == 1))/* no sub-sample */
|
&& (img->comps[2].dy == 1))/* no sub-sample */
|
||||||
{
|
{
|
||||||
sycc444_to_rgb(img);
|
sycc444_to_rgb(img);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
fprintf(stderr,"%s:%d:color_sycc_to_rgb\n\tCAN NOT CONVERT\n",
|
fprintf(stderr,"%s:%d:color_sycc_to_rgb\n\tCAN NOT CONVERT\n", __FILE__,__LINE__);
|
||||||
__FILE__,__LINE__);
|
return;
|
||||||
return;
|
}
|
||||||
}
|
|
||||||
img->color_space = CLRSPC_SRGB;
|
img->color_space = CLRSPC_SRGB;
|
||||||
|
|
||||||
}/* color_sycc_to_rgb() */
|
}/* color_sycc_to_rgb() */
|
||||||
|
|
||||||
#if defined(HAVE_LIBLCMS2) || defined(HAVE_LIBLCMS1)
|
#if defined(HAVE_LIBLCMS2) || defined(HAVE_LIBLCMS1)
|
||||||
|
|
Loading…
Reference in New Issue