summaryrefslogtreecommitdiffstats
path: root/xacodec.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-10-23 01:14:13 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2001-10-23 01:14:13 +0000
commit65348b282ea2a1aca7bdf4eb5e0d0f6bdeedc8ea (patch)
tree3396eb793698a9daedec6674a323677ce7845e6a /xacodec.c
parent7ce52c4998b4f3f35228a418ef0e0aac274d9279 (diff)
downloadmpv-65348b282ea2a1aca7bdf4eb5e0d0f6bdeedc8ea.tar.bz2
mpv-65348b282ea2a1aca7bdf4eb5e0d0f6bdeedc8ea.tar.xz
iv32 color scaling fix
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@2398 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'xacodec.c')
-rw-r--r--xacodec.c26
1 files changed, 22 insertions, 4 deletions
diff --git a/xacodec.c b/xacodec.c
index 49520e3c4e..02a974e1ea 100644
--- a/xacodec.c
+++ b/xacodec.c
@@ -599,6 +599,13 @@ void XA_YUV1611_To_CLR8(unsigned char *image_p, unsigned int imagex, unsigned in
int uvstride;
#if 0
+ printf("YUVTabs: %d %p %p %p %p %p\n",yuv_tabs->Uskip_mask,
+ yuv_tabs->YUV_Y_tab,
+ yuv_tabs->YUV_UB_tab,
+ yuv_tabs->YUV_VR_tab,
+ yuv_tabs->YUV_UG_tab,
+ yuv_tabs->YUV_VG_tab );
+
XA_Print("XA_YUV1611_To_CLR8('image: %08x', 'imagex: %d', 'imagey: %d', 'i_x: %d', 'i_y: %d', 'yuv_bufs: %08x', 'yuv_tabs: %08x', 'map_flag: %d', 'map: %08x', 'chdr: %08x')",
image, imagex, imagey, i_x, i_y, yuv, yuv_tabs, map_flag, map, chdr);
@@ -608,7 +615,11 @@ void XA_YUV1611_To_CLR8(unsigned char *image_p, unsigned int imagex, unsigned in
#endif
// copy Y plane:
- memcpy(image->planes[0],yuv->Ybuf,imagex*imagey);
+ if(yuv_tabs->YUV_Y_tab){ // dirty hack to detect iv32:
+ for(y=0;y<imagey*imagex;y++)
+ image->planes[0][y]=yuv->Ybuf[y]<<1;
+ } else
+ memcpy(image->planes[0],yuv->Ybuf,imagex*imagey);
// scale U,V planes by 2:
imagex>>=2;
@@ -624,9 +635,16 @@ void XA_YUV1611_To_CLR8(unsigned char *image_p, unsigned int imagex, unsigned in
unsigned char *du=image->planes[1]+2*y*strideu;
unsigned char *dv=image->planes[2]+2*y*stridev;
int x;
- for(x=0;x<imagex;x++){
- du[2*x]=du[2*x+1]=du[2*x+strideu]=du[2*x+strideu+1]=su[x];
- dv[2*x]=dv[2*x+1]=dv[2*x+stridev]=dv[2*x+stridev+1]=sv[x];
+ if(yuv_tabs->YUV_Y_tab){ // dirty hack to detect iv32:
+ for(x=0;x<imagex;x++){
+ du[2*x]=du[2*x+1]=du[2*x+strideu]=du[2*x+strideu+1]=su[x]*2;
+ dv[2*x]=dv[2*x+1]=dv[2*x+stridev]=dv[2*x+stridev+1]=sv[x]*2;
+ }
+ } else {
+ for(x=0;x<imagex;x++){
+ du[2*x]=du[2*x+1]=du[2*x+strideu]=du[2*x+strideu+1]=su[x];
+ dv[2*x]=dv[2*x+1]=dv[2*x+stridev]=dv[2*x+stridev+1]=sv[x];
+ }
}
}