# HG changeset patch # User nick # Date 1015604154 0 # Node ID ad943b99610aaf8f33c623fe2d41096e42af0a76 # Parent 6e39ed017ab1b89b85adb6b2195ae0d22156a206 VOCTRL_GET_IMAGE (untested but should work) diff -r 6e39ed017ab1 -r ad943b99610a libvo/vosub_vidix.c --- a/libvo/vosub_vidix.c Fri Mar 08 07:15:50 2002 +0000 +++ b/libvo/vosub_vidix.c Fri Mar 08 16:15:54 2002 +0000 @@ -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 @@ 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 @@ 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; }