# HG changeset patch # User arpi # Date 1038701353 0 # Node ID ca24204fb5476daa767275d46c28f3e0abf16778 # Parent 3bc3cadc042b4a3f8e7c4ba346ae586b3a7deea0 SVQ1 support (ugly hack... - really we need 'syuv' support in swscaler :)) diff -r 3bc3cadc042b -r ca24204fb547 libmpcodecs/vd_qtvideo.c --- a/libmpcodecs/vd_qtvideo.c Sat Nov 30 23:51:08 2002 +0000 +++ b/libmpcodecs/vd_qtvideo.c Sun Dec 01 00:09:13 2002 +0000 @@ -266,6 +266,7 @@ // decode a frame static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ long result = 1; + int i; mp_image_t* mpi; ComponentResult cres; @@ -347,10 +348,47 @@ #endif cres=ImageCodecBandDecompress(ci,&decpar); - if(cres&0xFFFF) printf("ImageCodecBandDecompress cres=0x%X (-0x%X) %d\n",cres,-cres,cres); ++decpar.frameNumber; + + if(cres&0xFFFF){ + printf("ImageCodecBandDecompress cres=0x%X (-0x%X) %d\n",cres,-cres,cres); + return NULL; + } +// for(i=0;i<8;i++) +// printf("img_base[%d]=%p\n",i,((int*)decpar.dstPixMap.baseAddr)[i]); + +if((int)sh->context==0x73797639){ // Sorenson 16-bit YUV -> std YVU9 + + short *src0=((char*)decpar.dstPixMap.baseAddr+0x20); + + for(i=0;ih;i++){ + int x; + unsigned char* dst=mpi->planes[0]+i*mpi->stride[0]; + unsigned short* src=src0+i*((mpi->w+15)&(~15)); + for(x=0;xw;x++) dst[x]=src[x]; + } + src0+=((mpi->w+15)&(~15))*((mpi->h+15)&(~15)); + for(i=0;ih/4;i++){ + int x; + unsigned char* dst=mpi->planes[1]+i*mpi->stride[1]; + unsigned short* src=src0+i*(((mpi->w+63)&(~63))/4); + for(x=0;xw/4;x++) dst[x]=src[x]; + src+=((mpi->w+63)&(~63))/4; + } + src0+=(((mpi->w+63)&(~63))/4)*(((mpi->h+63)&(~63))/4); + for(i=0;ih/4;i++){ + int x; + unsigned char* dst=mpi->planes[2]+i*mpi->stride[2]; + unsigned short* src=src0+i*(((mpi->w+63)&(~63))/4); + for(x=0;xw/4;x++) dst[x]=src[x]; + src+=((mpi->w+63)&(~63))/4; + } + +} + + return mpi; } #endif