summaryrefslogtreecommitdiffstats
path: root/libvo/vosub_vidix.c
diff options
context:
space:
mode:
authornick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-08 16:15:54 +0000
committernick <nick@b3059339-0415-0410-9bf9-f77b7e298cf2>2002-03-08 16:15:54 +0000
commit87de61ff9679ed9489b3633c42e2d38400fd7e71 (patch)
tree33bbf3dc421f7da993a18b6c9f44831094f574f5 /libvo/vosub_vidix.c
parent35f0ba3e19b9deaea4fe13d687bdfcbd8b449c54 (diff)
downloadmpv-87de61ff9679ed9489b3633c42e2d38400fd7e71.tar.bz2
mpv-87de61ff9679ed9489b3633c42e2d38400fd7e71.tar.xz
VOCTRL_GET_IMAGE (untested but should work)
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@4992 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libvo/vosub_vidix.c')
-rw-r--r--libvo/vosub_vidix.c21
1 files changed, 21 insertions, 0 deletions
diff --git a/libvo/vosub_vidix.c b/libvo/vosub_vidix.c
index 6bd5038bb7..833d284eab 100644
--- a/libvo/vosub_vidix.c
+++ b/libvo/vosub_vidix.c
@@ -28,6 +28,8 @@
#include "fastmemcpy.h"
#include "osd.h"
#include "video_out.h"
+#include "../mp_image.h"
+
#define NUM_FRAMES VID_PLAY_MAXFRAMES /* Temporary: driver will overwrite it */
#define UNUSED(x) ((void)(x)) /* Removes warning about unused arguments */
@@ -658,6 +660,23 @@ int vidix_init(unsigned src_width,unsigned src_height,
return 0;
}
+static uint32_t vidix_get_image(mp_image_t *mpi)
+{
+ if(mpi->type==MP_IMGTYPE_STATIC && vidix_play.num_frames>1) return VO_FALSE;
+ if(mpi->flags&MP_IMGFLAG_READABLE) return VO_FALSE; /* slow video ram */
+ mpi->planes[0]=vidix_mem+vidix_play.offsets[next_frame]+vidix_play.offset.y;
+ mpi->stride[0]=vidix_play.dest.pitch.y;
+ if(mpi->flags&MP_IMGFLAG_PLANAR)
+ {
+ mpi->planes[1]=vidix_mem+vidix_play.offsets[next_frame]+vidix_play.offset.v;
+ mpi->stride[1]=vidix_play.dest.pitch.v;
+ mpi->planes[2]=vidix_mem+vidix_play.offsets[next_frame]+vidix_play.offset.u;
+ mpi->stride[2]=vidix_play.dest.pitch.u;
+ }
+ mpi->flags|=MP_IMGFLAG_DIRECT;
+ return VO_TRUE;
+}
+
uint32_t vidix_control(uint32_t request, void *data, ...)
{
switch (request) {
@@ -668,6 +687,8 @@ uint32_t vidix_control(uint32_t request, void *data, ...)
return vidix_query_fourcc(*((uint32_t*)data));
case VOCTRL_SCREENSHOT:
return (*server_control)(request,data);
+ case VOCTRL_GET_IMAGE:
+ return vidix_get_image(data);
}
return VO_NOTIMPL;
}