Mercurial > mplayer.hg
changeset 2229:ad393ff770f4
16bpp code for atmos
author | arpi |
---|---|
date | Tue, 16 Oct 2001 23:58:17 +0000 |
parents | ac517956d9b0 |
children | 3f7a5bf1f9f4 |
files | postproc/swscale.c postproc/swscale_template.c |
diffstat | 2 files changed, 20 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/postproc/swscale.c Tue Oct 16 23:30:38 2001 +0000 +++ b/postproc/swscale.c Tue Oct 16 23:58:17 2001 +0000 @@ -96,9 +96,19 @@ int Y=yuvtab_2568[((buf0[i]*yalpha1+buf1[i]*yalpha)>>16)]; int U=((uvbuf0[i]*uvalpha1+uvbuf1[i]*uvalpha)>>16); int V=((uvbuf0[i+2048]*uvalpha1+uvbuf1[i+2048]*uvalpha)>>16); +#if 1 + // 24/32 bpp dest[0]=clip_table[((Y + yuvtab_3343[U]) >>13)]; dest[1]=clip_table[((Y + yuvtab_0c92[V] + yuvtab_1a1e[U]) >>13)]; dest[2]=clip_table[((Y + yuvtab_40cf[V]) >>13)]; +#else + unsigned short *d=dest; + unsigned int r=clip_table[((Y + yuvtab_3343[U]) >>13)]; + unsigned int g=clip_table[((Y + yuvtab_0c92[V] + yuvtab_1a1e[U]) >>13)]; + unsigned int b=clip_table[((Y + yuvtab_40cf[V]) >>13)]; + d[0]=((r>>3)<<10)|((g>>3)<<5)|((b>>3)); // 15bpp +// d[0]=((r>>3)<<11)|((g>>2)<<5)|((b>>3)); // 16bpp +#endif dest+=dstbpp; }
--- a/postproc/swscale_template.c Tue Oct 16 23:30:38 2001 +0000 +++ b/postproc/swscale_template.c Tue Oct 16 23:58:17 2001 +0000 @@ -96,9 +96,19 @@ int Y=yuvtab_2568[((buf0[i]*yalpha1+buf1[i]*yalpha)>>16)]; int U=((uvbuf0[i]*uvalpha1+uvbuf1[i]*uvalpha)>>16); int V=((uvbuf0[i+2048]*uvalpha1+uvbuf1[i+2048]*uvalpha)>>16); +#if 1 + // 24/32 bpp dest[0]=clip_table[((Y + yuvtab_3343[U]) >>13)]; dest[1]=clip_table[((Y + yuvtab_0c92[V] + yuvtab_1a1e[U]) >>13)]; dest[2]=clip_table[((Y + yuvtab_40cf[V]) >>13)]; +#else + unsigned short *d=dest; + unsigned int r=clip_table[((Y + yuvtab_3343[U]) >>13)]; + unsigned int g=clip_table[((Y + yuvtab_0c92[V] + yuvtab_1a1e[U]) >>13)]; + unsigned int b=clip_table[((Y + yuvtab_40cf[V]) >>13)]; + d[0]=((r>>3)<<10)|((g>>3)<<5)|((b>>3)); // 15bpp +// d[0]=((r>>3)<<11)|((g>>2)<<5)|((b>>3)); // 16bpp +#endif dest+=dstbpp; }