annotate imgconvert.c @ 0:986e461dc072 libavcodec

Initial revision
author glantau
date Sun, 22 Jul 2001 14:18:56 +0000
parents
children b69fe46fd708
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
986e461dc072 Initial revision
glantau
parents:
diff changeset
1 /*
986e461dc072 Initial revision
glantau
parents:
diff changeset
2 * Misc image convertion routines
986e461dc072 Initial revision
glantau
parents:
diff changeset
3 * Copyright (c) 2001 Gerard Lantau.
986e461dc072 Initial revision
glantau
parents:
diff changeset
4 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
5 * This program is free software; you can redistribute it and/or modify
986e461dc072 Initial revision
glantau
parents:
diff changeset
6 * it under the terms of the GNU General Public License as published by
986e461dc072 Initial revision
glantau
parents:
diff changeset
7 * the Free Software Foundation; either version 2 of the License, or
986e461dc072 Initial revision
glantau
parents:
diff changeset
8 * (at your option) any later version.
986e461dc072 Initial revision
glantau
parents:
diff changeset
9 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
10 * This program is distributed in the hope that it will be useful,
986e461dc072 Initial revision
glantau
parents:
diff changeset
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
986e461dc072 Initial revision
glantau
parents:
diff changeset
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
986e461dc072 Initial revision
glantau
parents:
diff changeset
13 * GNU General Public License for more details.
986e461dc072 Initial revision
glantau
parents:
diff changeset
14 *
986e461dc072 Initial revision
glantau
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License
986e461dc072 Initial revision
glantau
parents:
diff changeset
16 * along with this program; if not, write to the Free Software
986e461dc072 Initial revision
glantau
parents:
diff changeset
17 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
986e461dc072 Initial revision
glantau
parents:
diff changeset
18 */
986e461dc072 Initial revision
glantau
parents:
diff changeset
19 #include <stdlib.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
20 #include <stdio.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
21 #include <string.h>
986e461dc072 Initial revision
glantau
parents:
diff changeset
22 #include "avcodec.h"
986e461dc072 Initial revision
glantau
parents:
diff changeset
23
986e461dc072 Initial revision
glantau
parents:
diff changeset
24 /* XXX: totally non optimized */
986e461dc072 Initial revision
glantau
parents:
diff changeset
25
986e461dc072 Initial revision
glantau
parents:
diff changeset
26 static void yuv422_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
27 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
28 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
29 int x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
30 UINT8 *p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
31
986e461dc072 Initial revision
glantau
parents:
diff changeset
32 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
33 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
34 lum[0] = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
35 cb[0] = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
36 lum[1] = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
37 cr[0] = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
38 p += 4;
986e461dc072 Initial revision
glantau
parents:
diff changeset
39 lum += 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
40 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
41 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
42 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
43 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
44 lum[0] = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
45 lum[1] = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
46 p += 4;
986e461dc072 Initial revision
glantau
parents:
diff changeset
47 lum += 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
48 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
49 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
50 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
51
986e461dc072 Initial revision
glantau
parents:
diff changeset
52 #define SCALEBITS 8
986e461dc072 Initial revision
glantau
parents:
diff changeset
53 #define ONE_HALF (1 << (SCALEBITS - 1))
986e461dc072 Initial revision
glantau
parents:
diff changeset
54 #define FIX(x) ((int) ((x) * (1L<<SCALEBITS) + 0.5))
986e461dc072 Initial revision
glantau
parents:
diff changeset
55
986e461dc072 Initial revision
glantau
parents:
diff changeset
56 static void rgb24_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
57 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
58 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
59 int wrap, wrap3, x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
60 int r, g, b, r1, g1, b1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
61 UINT8 *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
62
986e461dc072 Initial revision
glantau
parents:
diff changeset
63 wrap = width;
986e461dc072 Initial revision
glantau
parents:
diff changeset
64 wrap3 = width * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
65 p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
66 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
67 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
68 r = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
69 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
70 b = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
71 r1 = r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
72 g1 = g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
73 b1 = b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
74 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
75 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
76 r = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
77 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
78 b = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
79 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
80 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
81 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
82 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
83 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
84 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
85 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
86
986e461dc072 Initial revision
glantau
parents:
diff changeset
87 r = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
88 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
89 b = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
90 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
91 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
92 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
93 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
94 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
95 r = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
96 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
97 b = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
98 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
99 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
100 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
101 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
102 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
103
986e461dc072 Initial revision
glantau
parents:
diff changeset
104 cb[0] = ((- FIX(0.16874) * r1 - FIX(0.33126) * g1 +
986e461dc072 Initial revision
glantau
parents:
diff changeset
105 FIX(0.50000) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
106 cr[0] = ((FIX(0.50000) * r1 - FIX(0.41869) * g1 -
986e461dc072 Initial revision
glantau
parents:
diff changeset
107 FIX(0.08131) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
108
986e461dc072 Initial revision
glantau
parents:
diff changeset
109 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
110 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
111 p += -wrap3 + 2 * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
112 lum += -wrap + 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
113 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
114 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
115 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
116 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
117 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
118
986e461dc072 Initial revision
glantau
parents:
diff changeset
119 static void bgr24_to_yuv420p(UINT8 *lum, UINT8 *cb, UINT8 *cr,
986e461dc072 Initial revision
glantau
parents:
diff changeset
120 UINT8 *src, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
121 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
122 int wrap, wrap3, x, y;
986e461dc072 Initial revision
glantau
parents:
diff changeset
123 int r, g, b, r1, g1, b1;
986e461dc072 Initial revision
glantau
parents:
diff changeset
124 UINT8 *p;
986e461dc072 Initial revision
glantau
parents:
diff changeset
125
986e461dc072 Initial revision
glantau
parents:
diff changeset
126 wrap = width;
986e461dc072 Initial revision
glantau
parents:
diff changeset
127 wrap3 = width * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
128 p = src;
986e461dc072 Initial revision
glantau
parents:
diff changeset
129 for(y=0;y<height;y+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
130 for(x=0;x<width;x+=2) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
131 b = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
132 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
133 r = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
134 r1 = r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
135 g1 = g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
136 b1 = b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
137 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
138 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
139 b = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
140 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
141 r = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
142 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
143 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
144 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
145 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
146 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
147 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
148 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
149
986e461dc072 Initial revision
glantau
parents:
diff changeset
150 b = p[0];
986e461dc072 Initial revision
glantau
parents:
diff changeset
151 g = p[1];
986e461dc072 Initial revision
glantau
parents:
diff changeset
152 r = p[2];
986e461dc072 Initial revision
glantau
parents:
diff changeset
153 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
154 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
155 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
156 lum[0] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
157 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
158 b = p[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
159 g = p[4];
986e461dc072 Initial revision
glantau
parents:
diff changeset
160 r = p[5];
986e461dc072 Initial revision
glantau
parents:
diff changeset
161 r1 += r;
986e461dc072 Initial revision
glantau
parents:
diff changeset
162 g1 += g;
986e461dc072 Initial revision
glantau
parents:
diff changeset
163 b1 += b;
986e461dc072 Initial revision
glantau
parents:
diff changeset
164 lum[1] = (FIX(0.29900) * r + FIX(0.58700) * g +
986e461dc072 Initial revision
glantau
parents:
diff changeset
165 FIX(0.11400) * b + ONE_HALF) >> SCALEBITS;
986e461dc072 Initial revision
glantau
parents:
diff changeset
166
986e461dc072 Initial revision
glantau
parents:
diff changeset
167 cb[0] = ((- FIX(0.16874) * r1 - FIX(0.33126) * g1 +
986e461dc072 Initial revision
glantau
parents:
diff changeset
168 FIX(0.50000) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
169 cr[0] = ((FIX(0.50000) * r1 - FIX(0.41869) * g1 -
986e461dc072 Initial revision
glantau
parents:
diff changeset
170 FIX(0.08131) * b1 + 4 * ONE_HALF - 1) >> (SCALEBITS + 2)) + 128;
986e461dc072 Initial revision
glantau
parents:
diff changeset
171
986e461dc072 Initial revision
glantau
parents:
diff changeset
172 cb++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
173 cr++;
986e461dc072 Initial revision
glantau
parents:
diff changeset
174 p += -wrap3 + 2 * 3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
175 lum += -wrap + 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
176 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
177 p += wrap3;
986e461dc072 Initial revision
glantau
parents:
diff changeset
178 lum += wrap;
986e461dc072 Initial revision
glantau
parents:
diff changeset
179 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
180 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
181
986e461dc072 Initial revision
glantau
parents:
diff changeset
182 int img_convert_to_yuv420(UINT8 *img_out, UINT8 *img,
986e461dc072 Initial revision
glantau
parents:
diff changeset
183 int pix_fmt, int width, int height)
986e461dc072 Initial revision
glantau
parents:
diff changeset
184 {
986e461dc072 Initial revision
glantau
parents:
diff changeset
185 UINT8 *pict;
986e461dc072 Initial revision
glantau
parents:
diff changeset
186 int size, size_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
187 UINT8 *picture[3];
986e461dc072 Initial revision
glantau
parents:
diff changeset
188
986e461dc072 Initial revision
glantau
parents:
diff changeset
189 pict = img_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
190 size = width * height;
986e461dc072 Initial revision
glantau
parents:
diff changeset
191 size_out = (size * 3) / 2;
986e461dc072 Initial revision
glantau
parents:
diff changeset
192 picture[0] = pict;
986e461dc072 Initial revision
glantau
parents:
diff changeset
193 picture[1] = pict + size;
986e461dc072 Initial revision
glantau
parents:
diff changeset
194 picture[2] = picture[1] + (size / 4);
986e461dc072 Initial revision
glantau
parents:
diff changeset
195
986e461dc072 Initial revision
glantau
parents:
diff changeset
196 switch(pix_fmt) {
986e461dc072 Initial revision
glantau
parents:
diff changeset
197 case PIX_FMT_YUV420P:
986e461dc072 Initial revision
glantau
parents:
diff changeset
198 memcpy(pict, img, size_out);
986e461dc072 Initial revision
glantau
parents:
diff changeset
199 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
200 case PIX_FMT_YUV422:
986e461dc072 Initial revision
glantau
parents:
diff changeset
201 yuv422_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
202 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
203 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
204 case PIX_FMT_RGB24:
986e461dc072 Initial revision
glantau
parents:
diff changeset
205 rgb24_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
206 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
207 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
208 case PIX_FMT_BGR24:
986e461dc072 Initial revision
glantau
parents:
diff changeset
209 bgr24_to_yuv420p(picture[0], picture[1], picture[2],
986e461dc072 Initial revision
glantau
parents:
diff changeset
210 img, width, height);
986e461dc072 Initial revision
glantau
parents:
diff changeset
211 break;
986e461dc072 Initial revision
glantau
parents:
diff changeset
212 }
986e461dc072 Initial revision
glantau
parents:
diff changeset
213 return size_out;
986e461dc072 Initial revision
glantau
parents:
diff changeset
214 }