summaryrefslogtreecommitdiffstats
path: root/libmpcodecs/vd_xanim.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-07 01:39:07 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-07 01:39:07 +0000
commit0827d3b1a76f61d4ecf3d8ceac9fa158521e3c92 (patch)
tree78ede64c62ef032115393323e11c55441d0c1b30 /libmpcodecs/vd_xanim.c
parent15222e9be6f4200bedb966db3ff5cf64a1866345 (diff)
downloadmpv-0827d3b1a76f61d4ecf3d8ceac9fa158521e3c92.tar.bz2
mpv-0827d3b1a76f61d4ecf3d8ceac9fa158521e3c92.tar.xz
xanim, raw, rle added
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@4970 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs/vd_xanim.c')
-rw-r--r--libmpcodecs/vd_xanim.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/libmpcodecs/vd_xanim.c b/libmpcodecs/vd_xanim.c
new file mode 100644
index 0000000000..e0806507fc
--- /dev/null
+++ b/libmpcodecs/vd_xanim.c
@@ -0,0 +1,74 @@
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "config.h"
+#ifdef USE_XANIM
+
+#include "mp_msg.h"
+
+#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 = {
+ "XAnim codecs",
+ "xanim",
+ VFM_XANIM,
+ "A'rpi & Alex",
+ "XAnim... TODO: name+url here",
+ "binary codec plugins"
+};
+
+LIBVD_EXTERN(xanim)
+
+#include "xacodec.h"
+
+// to set/get/query special features/parameters
+static int control(sh_video_t *sh,int cmd,void* arg,...){
+ return CONTROL_UNKNOWN;
+}
+
+// init driver
+static int init(sh_video_t *sh){
+ mpcodecs_config_vo(sh,sh->disp_w,sh->disp_h,sh->format);
+ return xacodec_init_video(sh,sh->codec->outfmt[sh->outfmtidx]);
+}
+
+// uninit driver
+static void uninit(sh_video_t *sh){
+ xacodec_exit();
+}
+
+//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;
+ xacodec_image_t* image;
+
+ if(len<=0) return NULL; // skipped frame
+
+ image=xacodec_decode_frame(data,len,(flags&3)?1:0);
+ if(!image) return NULL;
+
+ mpi=mpcodecs_get_image(sh, MP_IMGTYPE_EXPORT, MP_IMGFLAG_PRESERVE,
+ sh->disp_w, sh->disp_h);
+ if(!mpi) return NULL;
+
+ mpi->planes[0]=image->planes[0];
+ mpi->planes[1]=image->planes[1];
+ mpi->planes[2]=image->planes[2];
+ mpi->stride[0]=image->stride[0];
+ mpi->stride[1]=image->stride[1];
+ mpi->stride[2]=image->stride[2];
+
+ return mpi;
+}
+
+#endif