summaryrefslogtreecommitdiffstats
path: root/libmpcodecs/vf_scale.c
diff options
context:
space:
mode:
authorarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2003-02-23 20:40:46 +0000
committerarpi <arpi@b3059339-0415-0410-9bf9-f77b7e298cf2>2003-02-23 20:40:46 +0000
commit2074da4092181ade044eff1f9819f8cfeb043bb9 (patch)
treebccc97c8b5dd1e59c3fb774217511977700f59b7 /libmpcodecs/vf_scale.c
parent0020d4b05c1a8fada2deb0e2a84ac1cf82febb93 (diff)
downloadmpv-2074da4092181ade044eff1f9819f8cfeb043bb9.tar.bz2
mpv-2074da4092181ade044eff1f9819f8cfeb043bb9.tar.xz
draw_slice support
git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@9492 b3059339-0415-0410-9bf9-f77b7e298cf2
Diffstat (limited to 'libmpcodecs/vf_scale.c')
-rw-r--r--libmpcodecs/vf_scale.c33
1 files changed, 32 insertions, 1 deletions
diff --git a/libmpcodecs/vf_scale.c b/libmpcodecs/vf_scale.c
index 5739a0601c..2435121619 100644
--- a/libmpcodecs/vf_scale.c
+++ b/libmpcodecs/vf_scale.c
@@ -20,6 +20,7 @@ struct vf_priv_s {
unsigned int fmt;
SwsContext *ctx;
unsigned char* palette;
+ mp_image_t *dmpi;
};
extern int opt_screen_size_x;
@@ -199,15 +200,43 @@ static int config(struct vf_instance_s* vf,
return vf_next_config(vf,vf->priv->w,vf->priv->h,d_width,d_height,flags,best);
}
+static void start_slice(struct vf_instance_s* vf, mp_image_t *mpi){
+// printf("start_slice called! flag=%d\n",mpi->flags&MP_IMGFLAG_DRAW_CALLBACK);
+ if(!(mpi->flags&MP_IMGFLAG_DRAW_CALLBACK)) return; // shouldn't happen
+ // they want slices!!! allocate the buffer.
+ mpi->priv=vf->priv->dmpi=vf_get_image(vf->next,vf->priv->fmt,
+// mpi->type, mpi->flags & (~MP_IMGFLAG_DRAW_CALLBACK),
+ MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE,
+ vf->priv->w, vf->priv->h);
+}
+
+static void draw_slice(struct vf_instance_s* vf,
+ unsigned char** src, int* stride, int w,int h, int x, int y){
+ mp_image_t *dmpi=vf->priv->dmpi;
+ if(!dmpi){
+ mp_msg(MSGT_VFILTER,MSGL_FATAL,"vf_scale: draw_slice() called with dmpi=NULL (no get_image??)\n");
+ return;
+ }
+// printf("vf_scale::draw_slice() y=%d h=%d\n",y,h);
+ vf->priv->ctx->swScale(vf->priv->ctx,src,stride,y,h,dmpi->planes,dmpi->stride);
+}
+
static int put_image(struct vf_instance_s* vf, mp_image_t *mpi){
- mp_image_t *dmpi;
+ mp_image_t *dmpi=mpi->priv;
+// printf("vf_scale::put_image(): processing whole frame! dmpi=%p flag=%d\n",
+// dmpi, (mpi->flags&MP_IMGFLAG_DRAW_CALLBACK));
+
+ if(!(mpi->flags&MP_IMGFLAG_DRAW_CALLBACK && dmpi)){
+
// hope we'll get DR buffer:
dmpi=vf_get_image(vf->next,vf->priv->fmt,
MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE | MP_IMGFLAG_PREFER_ALIGNED_STRIDE,
vf->priv->w, vf->priv->h);
vf->priv->ctx->swScale(vf->priv->ctx,mpi->planes,mpi->stride,0,mpi->h,dmpi->planes,dmpi->stride);
+ }
+
if(vf->priv->w==mpi->w && vf->priv->h==mpi->h){
// just conversion, no scaling -> keep postprocessing data
// this way we can apply pp filter to non-yv12 source using scaler
@@ -314,6 +343,8 @@ static int query_format(struct vf_instance_s* vf, unsigned int fmt){
static int open(vf_instance_t *vf, char* args){
vf->config=config;
+ vf->start_slice=start_slice;
+ vf->draw_slice=draw_slice;
vf->put_image=put_image;
vf->query_format=query_format;
vf->control= control;