annotate libmpcodecs/vf_down3dright.c @ 9593:e9a2af584986

Add the new -vf option wich is the same as vop in reverse order. Syntax is we decided, so you can give the nomes or not with both vop and vf. vf take precedence over vop.
author albeu
date Sat, 15 Mar 2003 18:01:02 +0000
parents 7a43a52b9f60
children 55831d1b371b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
9404
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
1 #include <stdio.h>
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
2 #include <stdlib.h>
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
3 #include <string.h>
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
4 #include <inttypes.h>
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
5
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
6 #include "../config.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
7 #include "../mp_msg.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
8 #include "../cpudetect.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
9
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
10 #include "img_format.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
11 #include "mp_image.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
12 #include "vf.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
13
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
14 #include "../libvo/fastmemcpy.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
15 #include "../postproc/rgb2rgb.h"
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
16
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
17 struct vf_priv_s {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
18 int skipline;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
19 int scalew;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
20 int scaleh;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
21 };
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
22
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
23 static void toright(unsigned char *dst[3], unsigned char *src[3],
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
24 unsigned int dststride[3], unsigned int srcstride[3],
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
25 int w, int h, struct vf_priv_s* p)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
26 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
27 int k;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
28
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
29 for (k = 0; k < 3; k++) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
30 unsigned char* fromL = src[k];
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
31 unsigned char* fromR = src[k];
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
32 unsigned char* to = dst[k];
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
33 unsigned int src = srcstride[k];
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
34 unsigned int dst = dststride[k];
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
35 unsigned int ss;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
36 unsigned int dd;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
37 int i;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
38
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
39 if (k > 0) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
40 i = h / 4 - p->skipline / 2;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
41 ss = src * (h / 4 + p->skipline / 2);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
42 dd = w / 4;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
43 } else {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
44 i = h / 2 - p->skipline;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
45 ss = src * (h / 2 + p->skipline);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
46 dd = w / 2;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
47 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
48 fromR += ss;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
49 for ( ; i > 0; i--) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
50 int j;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
51 unsigned char* t = to;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
52 unsigned char* sL = fromL;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
53 unsigned char* sR = fromR;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
54
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
55 if (p->scalew == 1) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
56 for (j = dd; j > 0; j--)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
57 *t++ = (*sL++ + *sL++) / 2;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
58 for (j = dd ; j > 0; j--)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
59 *t++ = (*sR++ + *sR++) / 2;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
60 } else {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
61 for (j = dd * 2 ; j > 0; j--)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
62 *t++ = *sL++;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
63 for (j = dd * 2 ; j > 0; j--)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
64 *t++ = *sR++;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
65 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
66 if (p->scaleh == 1) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
67 memcpy(to + dst, to, dst);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
68 to += dst;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
69 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
70 to += dst;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
71 fromL += src;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
72 fromR += src;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
73 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
74 //printf("K %d %d %d %d %d \n", k, w, h, src, dst);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
75 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
76 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
77
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
78 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
79 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
80 mp_image_t *dmpi;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
81
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
82 // hope we'll get DR buffer:
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
83 dmpi=vf_get_image(vf->next, IMGFMT_YV12,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
84 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
85 mpi->w * vf->priv->scalew,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
86 mpi->h / vf->priv->scaleh - vf->priv->skipline);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
87
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
88 toright(dmpi->planes, mpi->planes, dmpi->stride,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
89 mpi->stride, mpi->w, mpi->h, vf->priv);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
90
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
91 return vf_next_put_image(vf,dmpi);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
92 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
93
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
94 static int config(struct vf_instance_s* vf,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
95 int width, int height, int d_width, int d_height,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
96 unsigned int flags, unsigned int outfmt)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
97 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
98 /* FIXME - also support UYVY output? */
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
99 return vf_next_config(vf, width * vf->priv->scalew,
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
100 height / vf->priv->scaleh - vf->priv->skipline, d_width, d_height, flags, IMGFMT_YV12);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
101 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
102
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
103
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
104 static int query_format(struct vf_instance_s* vf, unsigned int fmt)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
105 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
106 /* FIXME - really any YUV 4:2:0 input format should work */
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
107 switch (fmt) {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
108 case IMGFMT_YV12:
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
109 case IMGFMT_IYUV:
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
110 case IMGFMT_I420:
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
111 return vf_next_query_format(vf, IMGFMT_YV12);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
112 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
113 return 0;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
114 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
115
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
116 static void uninit(struct vf_instance_s* vf)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
117 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
118 free(vf->priv);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
119 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
120
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
121 static int open(vf_instance_t *vf, char* args)
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
122 {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
123 vf->config=config;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
124 vf->query_format=query_format;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
125 vf->put_image=put_image;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
126 vf->uninit=uninit;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
127
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
128 vf->priv = calloc(1, sizeof (struct vf_priv_s));
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
129 vf->priv->skipline = 0;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
130 vf->priv->scalew = 1;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
131 vf->priv->scaleh = 2;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
132 if (args) sscanf(args, "%d", &vf->priv->skipline);
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
133
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
134 return 1;
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
135 }
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
136
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
137 vf_info_t vf_info_down3dright = {
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
138 "convert stereo movie from top-bottom to left-right field",
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
139 "down3dright",
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
140 "Zdenek Kabelac",
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
141 "",
9593
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9404
diff changeset
142 open,
e9a2af584986 Add the new -vf option wich is the same as vop in reverse order.
albeu
parents: 9404
diff changeset
143 NULL
9404
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
144 };
7a43a52b9f60 down3dright filter by kabi (converts between 2 common stereoscopic systems)
michael
parents:
diff changeset
145