annotate libmpcodecs/vf_flip.c @ 5557:2d0b4090497f

new filter: flip
author arpi
date Thu, 11 Apr 2002 03:17:14 +0000
parents
children 0b301fec999a
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
5557
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
1 #include <stdio.h>
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
2 #include <stdlib.h>
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
3 #include <string.h>
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
4
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
5 #include "../config.h"
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
6 #include "../mp_msg.h"
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
7
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
8 #include "../mp_image.h"
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
9 #include "vf.h"
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
10
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
11 #include "../libvo/fastmemcpy.h"
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
12
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
13 struct vf_priv_s {
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
14 mp_image_t *dmpi;
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
15 };
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
16
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
17 //===========================================================================//
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
18
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
19 static void get_image(struct vf_instance_s* vf, mp_image_t *mpi){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
20 if(mpi->flags&MP_IMGFLAG_ACCEPT_STRIDE){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
21 // try full DR !
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
22 vf->priv->dmpi=vf_get_image(vf->next,mpi->imgfmt,
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
23 mpi->type, mpi->flags, mpi->width, mpi->height);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
24 // set up mpi as a upside-down image of dmpi:
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
25 mpi->planes[0]=vf->priv->dmpi->planes[0]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
26 vf->priv->dmpi->stride[0]*(vf->priv->dmpi->height-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
27 mpi->stride[0]=-vf->priv->dmpi->stride[0];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
28 if(mpi->flags&MP_IMGFLAG_PLANAR){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
29 mpi->planes[1]=vf->priv->dmpi->planes[1]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
30 vf->priv->dmpi->stride[1]*((vf->priv->dmpi->height>>1)-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
31 mpi->stride[1]=-vf->priv->dmpi->stride[1];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
32 mpi->planes[2]=vf->priv->dmpi->planes[2]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
33 vf->priv->dmpi->stride[2]*((vf->priv->dmpi->height>>1)-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
34 mpi->stride[2]=-vf->priv->dmpi->stride[2];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
35 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
36 mpi->flags|=MP_IMGFLAG_DIRECT;
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
37 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
38 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
39
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
40 static void put_image(struct vf_instance_s* vf, mp_image_t *mpi){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
41 if(mpi->flags&MP_IMGFLAG_DIRECT){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
42 vf_next_put_image(vf,vf->priv->dmpi);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
43 return; // we've used DR, so we're ready...
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
44 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
45
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
46 // hope we'll get DR buffer:
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
47 vf->priv->dmpi=vf_get_image(vf->next,mpi->imgfmt,
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
48 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE,
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
49 mpi->width, mpi->height);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
50
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
51 // set up mpi as a upside-down image of dmpi:
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
52 vf->priv->dmpi->planes[0]=mpi->planes[0]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
53 mpi->stride[0]*(mpi->height-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
54 vf->priv->dmpi->stride[0]=-mpi->stride[0];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
55 if(vf->priv->dmpi->flags&MP_IMGFLAG_PLANAR){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
56 vf->priv->dmpi->planes[1]=mpi->planes[1]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
57 mpi->stride[1]*((mpi->height>>1)-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
58 vf->priv->dmpi->stride[1]=-mpi->stride[1];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
59 vf->priv->dmpi->planes[2]=mpi->planes[2]+
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
60 mpi->stride[2]*((mpi->height>>1)-1);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
61 vf->priv->dmpi->stride[2]=-mpi->stride[2];
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
62 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
63
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
64 vf_next_put_image(vf,vf->priv->dmpi);
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
65 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
66
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
67 //===========================================================================//
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
68
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
69 static int open(vf_instance_t *vf, char* args){
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
70 vf->get_image=get_image;
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
71 vf->put_image=put_image;
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
72 vf->priv=malloc(sizeof(struct vf_priv_s));
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
73 return 1;
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
74 }
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
75
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
76 vf_info_t vf_info_flip = {
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
77 "flip image upside-down",
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
78 "flip",
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
79 "A'rpi",
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
80 "",
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
81 open
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
82 };
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
83
2d0b4090497f new filter: flip
arpi
parents:
diff changeset
84 //===========================================================================//