Mercurial > mplayer.hg
diff libmpcodecs/vd_divx4.c @ 4968:236b06410b03
vfw, vfwex, odivx, divx4 added
author | arpi |
---|---|
date | Thu, 07 Mar 2002 00:44:58 +0000 |
parents | |
children | eb57973314ae |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/libmpcodecs/vd_divx4.c Thu Mar 07 00:44:58 2002 +0000 @@ -0,0 +1,127 @@ +#include <stdio.h> +#include <stdlib.h> +#include <assert.h> + +#include "config.h" +#include "mp_msg.h" +#include "help_mp.h" + +#ifdef USE_DIVX +#ifdef NEW_DECORE + +#include "codec-cfg.h" +#include "../libvo/img_format.h" + +#include "stream.h" +#include "demuxer.h" +#include "stheader.h" + +#include "vd.h" +#include "vd_internal.h" + +static vd_info_t info = { +#ifdef DECORE_DIVX5 + "DivX5Linux lib (divx4 mode)", +#else + "DivX4Linux lib (divx4 mode)", +#endif + "divx4", + VFM_DIVX4, + "A'rpi", + "http://www.divx.com", + "native codecs" +}; + +LIBVD_EXTERN(divx4) + +#include <decore.h> + +// to set/get/query special features/parameters +static int control(sh_video_t *sh,int cmd,void* arg,...){ + switch(cmd){ + case VDCTRL_QUERY_MAX_PP_LEVEL: + return 9; // for divx4linux + case VDCTRL_SET_PP_LEVEL: { + DEC_SET dec_set; + int quality=*((int*)arg); + if(quality<0 || quality>9) quality=9; + dec_set.postproc_level=quality*10; + decore(0x123,DEC_OPT_SETPP,&dec_set,NULL); + return CONTROL_OK; + } + + } + + return CONTROL_UNKNOWN; +} + +// init driver +static int init(sh_video_t *sh){ + DEC_PARAM dec_param; +// DEC_SET dec_set; + int bits=16; + memset(&dec_param,0,sizeof(dec_param)); + + mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,IMGFMT_YUY2); + + switch(sh->codec->outfmt[sh->outfmtidx]){ + case IMGFMT_YV12: dec_param.output_format=DEC_YV12;bits=12;break; + case IMGFMT_YUY2: dec_param.output_format=DEC_YUY2;break; + case IMGFMT_UYVY: dec_param.output_format=DEC_UYVY;break; + case IMGFMT_I420: dec_param.output_format=DEC_420;bits=12;break; + case IMGFMT_BGR15: dec_param.output_format=DEC_RGB555_INV;break; + case IMGFMT_BGR16: dec_param.output_format=DEC_RGB565_INV;break; + case IMGFMT_BGR24: dec_param.output_format=DEC_RGB24_INV;bits=24;break; + case IMGFMT_BGR32: dec_param.output_format=DEC_RGB32_INV;bits=32;break; + default: + mp_msg(MSGT_DECVIDEO,MSGL_ERR,"Unsupported out_fmt: 0x%X\n",sh->codec->outfmt[sh->outfmtidx]); + return 0; + } + dec_param.x_dim = sh->disp_w; + dec_param.y_dim = sh->disp_h; + decore(0x123, DEC_OPT_INIT, &dec_param, NULL); +// dec_set.postproc_level = divx_quality; +// decore(0x123, DEC_OPT_SETPP, &dec_set, NULL); + + mp_msg(MSGT_DECVIDEO,MSGL_V,"INFO: DivX4Linux video codec init OK!\n"); + + return 1; +} + +// uninit driver +static void uninit(sh_video_t *sh){ + decore(0x123,DEC_OPT_RELEASE,NULL,NULL); +} + +//mp_image_t* mpcodecs_get_image(sh_video_t *sh, int mp_imgtype, int mp_imgflag, int w, int h); + +// decode a frame +static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ + mp_image_t* mpi; + DEC_FRAME dec_frame; + + if(len<=0) return NULL; // skipped frame + + dec_frame.length = len; + dec_frame.bitstream = data; + dec_frame.render_flag = (flags&3)?0:1; + + mpi=mpcodecs_get_image(sh, MP_IMGTYPE_TEMP, MP_IMGFLAG_PRESERVE | MP_IMGFLAG_ACCEPT_WIDTH, + sh->disp_w, sh->disp_h); + if(!mpi) return NULL; + + dec_frame.bmp=mpi->planes[0]; + dec_frame.stride=mpi->width; + +#ifdef DECORE_DIVX5 + decore(0x123, DEC_OPT_FRAME, &dec_frame, NULL); +#else + decore(0x123, (sh->format==mmioFOURCC('D','I','V','3'))?DEC_OPT_FRAME_311:DEC_OPT_FRAME, &dec_frame, NULL); +#endif + + return mpi; +} + +#endif +#endif +