# HG changeset patch # User arpi # Date 1016310984 0 # Node ID 109377795585ecfb60afde5f08869c4d4c129c23 # Parent 9651a7bb874d43b43b23b904f5148c90fae1a712 mpegpes support diff -r 9651a7bb874d -r 109377795585 libmpcodecs/vd_libmpeg2.c --- a/libmpcodecs/vd_libmpeg2.c Sat Mar 16 20:35:59 2002 +0000 +++ b/libmpcodecs/vd_libmpeg2.c Sat Mar 16 20:36:24 2002 +0000 @@ -48,9 +48,23 @@ // decode a frame static mp_image_t* decode(sh_video_t *sh,void* data,int len,int flags){ - mp_image_t* mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, MP_IMGFLAG_DRAW_CALLBACK, - sh->disp_w, sh->disp_h); - mpeg2_decode_data(sh->video_out, data, data+len,flags&3); // decode + mp_image_t* mpi; + if(sh->codec->outfmt[sh->outfmtidx]==IMGFMT_MPEGPES){ + static vo_mpegpes_t packet; + mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, 0, + sh->disp_w, sh->disp_h); + // hardware decoding: +// mpeg2_decode_data(video_out, start, start+in_size,3); // parse headers + packet.data=data; + packet.size=len-4; + packet.timestamp=sh->timer*90000.0; + packet.id=0x1E0; //+sh_video->ds->id; + mpi->planes[0]=(uint8_t*)(&packet); + } else { + mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, MP_IMGFLAG_DRAW_CALLBACK, + sh->disp_w, sh->disp_h); + mpeg2_decode_data(sh->video_out, data, data+len,flags&3); // decode + } return mpi; }