X-Git-Url: http://git.cinelerra-gg.org/git/?a=blobdiff_plain;f=cinelerra-5.1%2Fguicast%2Fxfer.h;h=508f977bdd949726c460d2f0368f9b1dad57f2bb;hb=a88121d876acc81c5a28dbd2cc71e7c6856e2ac0;hp=e6e0aba40b52a5bb365441d23e6aac3487c10b2d;hpb=9df45f6232e108a5f36ba415ff7da8a51ca9dbdc;p=goodguy%2Fhistory.git diff --git a/cinelerra-5.1/guicast/xfer.h b/cinelerra-5.1/guicast/xfer.h index e6e0aba4..508f977b 100644 --- a/cinelerra-5.1/guicast/xfer.h +++ b/cinelerra-5.1/guicast/xfer.h @@ -22,65 +22,6 @@ static inline float fclp(float v, const int n) { ZTYP(int); ZTYP(float); -// All variables are unsigned -// y -> 24 bits u, v, -> 8 bits r, g, b -> 8 bits -#define YUV_TO_RGB(y, u, v, r, g, b) \ -{ \ - (r) = ((y + vtor_tab[v]) >> 16); \ - (g) = ((y + utog_tab[u] + vtog_tab[v]) >> 16); \ - (b) = ((y + utob_tab[u]) >> 16); \ - CLAMP(r, 0, 0xff); CLAMP(g, 0, 0xff); CLAMP(b, 0, 0xff); \ -} - -// y -> 0 - 1 float -// u, v, -> 8 bits -// r, g, b -> float -#define YUV_TO_FLOAT(y, u, v, r, g, b) \ -{ \ - (r) = y + vtor_float_tab[v]; \ - (g) = y + utog_float_tab[u] + vtog_float_tab[v]; \ - (b) = y + utob_float_tab[u]; \ -} - -// y -> 0 - 1 float -// u, v, -> 16 bits -// r, g, b -> float -#define YUV16_TO_RGB_FLOAT(y, u, v, r, g, b) \ -{ \ - (r) = y + v16tor_float_tab[v]; \ - (g) = y + u16tog_float_tab[u] + v16tog_float_tab[v]; \ - (b) = y + u16tob_float_tab[u]; \ -} - -// y -> 24 bits u, v-> 16 bits -#define YUV_TO_RGB16(y, u, v, r, g, b) \ -{ \ - (r) = ((y + vtor_tab16[v]) >> 8); \ - (g) = ((y + utog_tab16[u] + vtog_tab16[v]) >> 8); \ - (b) = ((y + utob_tab16[u]) >> 8); \ - CLAMP(r, 0, 0xffff); CLAMP(g, 0, 0xffff); CLAMP(b, 0, 0xffff); \ -} - - - - -#define RGB_TO_YUV(y, u, v, r, g, b) \ -{ \ - y = ((rtoy_tab[r] + gtoy_tab[g] + btoy_tab[b]) >> 16); \ - u = ((rtou_tab[r] + gtou_tab[g] + btou_tab[b]) >> 16); \ - v = ((rtov_tab[r] + gtov_tab[g] + btov_tab[b]) >> 16); \ - CLAMP(y, 0, 0xff); CLAMP(u, 0, 0xff); CLAMP(v, 0, 0xff); \ -} - -// r, g, b -> 16 bits -#define RGB_TO_YUV16(y, u, v, r, g, b) \ -{ \ - y = ((rtoy_tab16[r] + gtoy_tab16[g] + btoy_tab16[b]) >> 8); \ - u = ((rtou_tab16[r] + gtou_tab16[g] + btou_tab16[b]) >> 8); \ - v = ((rtov_tab16[r] + gtov_tab16[g] + btov_tab16[b]) >> 8); \ - CLAMP(y, 0, 0xffff); CLAMP(u, 0, 0xffff); CLAMP(v, 0, 0xffff); \ -} - #define xfer_flat_row_out(oty_t) \ for( unsigned i=y0; i