annotate libmpcodecs/vf_swapuv.c @ 9180:5750570b4a46

10l for XYZ
author diego
date Thu, 30 Jan 2003 23:37:17 +0000
parents 5f630596d004
children e9a2af584986
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
1 /*
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
2 Copyright (C) 2002 Michael Niedermayer <michaelni@gmx.at>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
3
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
4 This program is free software; you can redistribute it and/or modify
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
6 the Free Software Foundation; either version 2 of the License, or
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
7 (at your option) any later version.
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
8
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
12 GNU General Public License for more details.
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
13
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
15 along with this program; if not, write to the Free Software
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
16 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
17 */
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
18
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
19 #include <stdio.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
20 #include <stdlib.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
21 #include <string.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
22 #include <inttypes.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
23 #include <assert.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
24
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
25 #include "../config.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
26 #include "../mp_msg.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
27
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
28 #ifdef HAVE_MALLOC_H
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
29 #include <malloc.h>
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
30 #endif
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
31
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
32 #include "img_format.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
33 #include "mp_image.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
34 #include "vf.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
35 #include "../libvo/fastmemcpy.h"
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
36
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
37
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
38 //===========================================================================//
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
39
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
40 static void get_image(struct vf_instance_s* vf, mp_image_t *mpi){
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
41 mp_image_t *dmpi= vf_get_image(vf->next, mpi->imgfmt,
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
42 mpi->type, mpi->flags, mpi->w, mpi->h);
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
43
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
44 mpi->planes[0]=dmpi->planes[0];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
45 mpi->planes[1]=dmpi->planes[2];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
46 mpi->planes[2]=dmpi->planes[1];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
47 mpi->stride[0]=dmpi->stride[0];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
48 mpi->stride[1]=dmpi->stride[2];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
49 mpi->stride[2]=dmpi->stride[1];
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
50 mpi->width=dmpi->width;
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
51
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
52 mpi->flags|=MP_IMGFLAG_DIRECT;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
53 mpi->priv=(void*)dmpi;
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
54 }
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
55
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
56 static int put_image(struct vf_instance_s* vf, mp_image_t *mpi){
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
57 mp_image_t *dmpi;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
58
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
59 if(mpi->flags&MP_IMGFLAG_DIRECT){
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
60 dmpi=(mp_image_t*)mpi->priv;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
61 } else {
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
62 dmpi=vf_get_image(vf->next, mpi->imgfmt, MP_IMGTYPE_EXPORT, 0, mpi->w, mpi->h);
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
63 assert(mpi->flags&MP_IMGFLAG_PLANAR);
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
64 dmpi->planes[0]=mpi->planes[0];
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
65 dmpi->planes[1]=mpi->planes[2];
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
66 dmpi->planes[2]=mpi->planes[1];
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
67 dmpi->stride[0]=mpi->stride[0];
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
68 dmpi->stride[1]=mpi->stride[2];
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
69 dmpi->stride[2]=mpi->stride[1];
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
70 dmpi->width=mpi->width;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
71 }
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
72
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
73 dmpi->qscale=mpi->qscale;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
74 dmpi->qstride=mpi->qstride;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
75 dmpi->pict_type=mpi->pict_type;
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
76
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
77 return vf_next_put_image(vf,dmpi);
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
78 }
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
79
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
80 //===========================================================================//
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
81
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
82 static int query_format(struct vf_instance_s* vf, unsigned int fmt){
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
83 switch(fmt)
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
84 {
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
85 case IMGFMT_YV12:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
86 case IMGFMT_I420:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
87 case IMGFMT_IYUV:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
88 case IMGFMT_YVU9:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
89 case IMGFMT_444P:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
90 case IMGFMT_422P:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
91 case IMGFMT_411P:
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
92 return vf_next_query_format(vf, fmt);
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
93 }
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
94 return 0;
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
95 }
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
96
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
97 static int open(vf_instance_t *vf, char* args){
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
98 vf->put_image=put_image;
8050
5f630596d004 - DR support
arpi
parents: 8002
diff changeset
99 vf->get_image=get_image;
8002
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
100 vf->query_format=query_format;
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
101 return 1;
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
102 }
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
103
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
104 vf_info_t vf_info_swapuv = {
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
105 "UV swaper",
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
106 "swapuv",
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
107 "Michael Niedermayer",
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
108 "",
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
109 open
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
110 };
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
111
84ff79ba83f0 (useless) UV plane swapper
michael
parents:
diff changeset
112 //===========================================================================//