Mercurial > mplayer.hg
annotate libmpcodecs/mp_image.h @ 10496:5fd0864becc3
remove cs_test and swscale-example too
author | alex |
---|---|
date | Mon, 28 Jul 2003 15:24:38 +0000 |
parents | fdc349b9bd1d |
children | 73b3e4336cd4 |
rev | line source |
---|---|
4933 | 1 #ifndef __MP_IMAGE_H |
2 #define __MP_IMAGE_H 1 | |
4185 | 3 |
6875 | 4 //--------- codec's requirements (filled by the codec/vf) --------- |
5 | |
6 //--- buffer content restrictions: | |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
7 // set if buffer content shouldn't be modified: |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
8 #define MP_IMGFLAG_PRESERVE 0x01 |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
9 // set if buffer content will be READ for next frame's MC: (I/P mpeg frames) |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
10 #define MP_IMGFLAG_READABLE 0x02 |
6875 | 11 |
12 //--- buffer width/stride/plane restrictions: (used for direct rendering) | |
13 // stride _have_to_ be aligned to MB boundary: [for DR restrictions] | |
14 #define MP_IMGFLAG_ACCEPT_ALIGNED_STRIDE 0x4 | |
15 // stride should be aligned to MB boundary: [for buffer allocation] | |
16 #define MP_IMGFLAG_PREFER_ALIGNED_STRIDE 0x8 | |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
17 // codec accept any stride (>=width): |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
18 #define MP_IMGFLAG_ACCEPT_STRIDE 0x10 |
6875 | 19 // codec accept any width (width*bpp=stride -> stride%bpp==0) (>=width): |
4962 | 20 #define MP_IMGFLAG_ACCEPT_WIDTH 0x20 |
6875 | 21 //--- for planar formats only: |
22 // uses only stride[0], and stride[1]=stride[2]=stride[0]>>mpi->chroma_x_shift | |
23 #define MP_IMGFLAG_COMMON_STRIDE 0x40 | |
24 // uses only planes[0], and calculates planes[1,2] from width,height,imgfmt | |
25 #define MP_IMGFLAG_COMMON_PLANE 0x80 | |
4185 | 26 |
6875 | 27 #define MP_IMGFLAGMASK_RESTRICTIONS 0xFF |
28 | |
29 //--------- color info (filled by mp_image_setfmt() ) ----------- | |
4185 | 30 // set if number of planes > 1 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
31 #define MP_IMGFLAG_PLANAR 0x100 |
4185 | 32 // set if it's YUV colorspace |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
33 #define MP_IMGFLAG_YUV 0x200 |
6875 | 34 // set if it's swapped (BGR or YVU) plane/byteorder |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
35 #define MP_IMGFLAG_SWAPPED 0x400 |
6478 | 36 // using palette for RGB data |
6875 | 37 #define MP_IMGFLAG_RGB_PALETTE 0x800 |
38 | |
39 #define MP_IMGFLAGMASK_COLORS 0xF00 | |
40 | |
41 // codec uses drawing/rendering callbacks (draw_slice()-like thing, DR method 2) | |
42 // [the codec will set this flag if it supports callbacks, and the vo _may_ | |
43 // clear it in get_image() if draw_slice() not implemented] | |
44 #define MP_IMGFLAG_DRAW_CALLBACK 0x1000 | |
45 // set if it's in video buffer/memory: [set by vo/vf's get_image() !!!] | |
46 #define MP_IMGFLAG_DIRECT 0x2000 | |
47 // set if buffer is allocated (used in destination images): | |
48 #define MP_IMGFLAG_ALLOCATED 0x4000 | |
49 | |
50 // buffer type was printed (do NOT set this flag - it's for INTERNAL USE!!!) | |
51 #define MP_IMGFLAG_TYPE_DISPLAYED 0x8000 | |
4185 | 52 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
53 // codec doesn't support any form of direct rendering - it has own buffer |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
54 // allocation. so we just export its buffer pointers: |
4186 | 55 #define MP_IMGTYPE_EXPORT 0 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
56 // codec requires a static WO buffer, but it does only partial updates later: |
4186 | 57 #define MP_IMGTYPE_STATIC 1 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
58 // codec just needs some WO memory, where it writes/copies the whole frame to: |
4186 | 59 #define MP_IMGTYPE_TEMP 2 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
60 // I+P type, requires 2+ independent static R/W buffers |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
61 #define MP_IMGTYPE_IP 3 |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
62 // I+P+B type, requires 2+ independent static R/W and 1+ temp WO buffers |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
63 #define MP_IMGTYPE_IPB 4 |
4186 | 64 |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
65 #define MP_MAX_PLANES 4 |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
66 |
4185 | 67 typedef struct mp_image_s { |
68 unsigned short flags; | |
4186 | 69 unsigned char type; |
70 unsigned char bpp; // bits/pixel. NOT depth! for RGB it will be n*8 | |
4185 | 71 unsigned int imgfmt; |
72 int width,height; // stored dimensions | |
73 int x,y,w,h; // visible dimensions | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
74 unsigned char* planes[MP_MAX_PLANES]; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
75 unsigned int stride[MP_MAX_PLANES]; |
7984
a57c1fc0c2fc
change qscale type to int8 and fix qscale ordering
michael
parents:
7957
diff
changeset
|
76 char * qscale; |
4185 | 77 int qstride; |
7957
31fd09cc9ba2
passing picture_type (might be usefull for postprocessing)
michael
parents:
6911
diff
changeset
|
78 int pict_type; // 0->unknown, 1->I, 2->P, 3->B |
9925
420640a0f6d0
passing qscale_type around so the pp code can fix the mpeg2 <<1 thing
michael
parents:
9171
diff
changeset
|
79 int qscale_type; // 0->mpeg1/4/h263, 1->mpeg2 |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
80 int num_planes; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
81 /* these are only used by planar formats Y,U(Cb),V(Cr) */ |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
82 int chroma_width; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
83 int chroma_height; |
6539
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
84 int chroma_x_shift; // horizontal |
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
85 int chroma_y_shift; // vertical |
6759
415be01747ae
added 'priv' field to mpi - requires for tracking frames with different
arpi
parents:
6707
diff
changeset
|
86 /* for private use by filter or vo driver (to store buffer id or dmpi) */ |
415be01747ae
added 'priv' field to mpi - requires for tracking frames with different
arpi
parents:
6707
diff
changeset
|
87 void* priv; |
4185 | 88 } mp_image_t; |
89 | |
90 #ifdef IMGFMT_YUY2 | |
91 static inline void mp_image_setfmt(mp_image_t* mpi,unsigned int out_fmt){ | |
92 mpi->flags&=~(MP_IMGFLAG_PLANAR|MP_IMGFLAG_YUV|MP_IMGFLAG_SWAPPED); | |
4187 | 93 mpi->imgfmt=out_fmt; |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
94 if(out_fmt == IMGFMT_MPEGPES){ |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
95 mpi->bpp=0; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
96 return; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
97 } |
10316 | 98 if(IMGFMT_IS_XVMC(out_fmt)){ |
99 mpi->bpp=0; | |
100 return; | |
101 } | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
102 mpi->num_planes=1; |
6707 | 103 if (IMGFMT_IS_RGB(out_fmt)) { |
9171 | 104 if (IMGFMT_RGB_DEPTH(out_fmt) < 8 && !(out_fmt&128)) |
6707 | 105 mpi->bpp = IMGFMT_RGB_DEPTH(out_fmt); |
106 else | |
107 mpi->bpp=(IMGFMT_RGB_DEPTH(out_fmt)+7)&(~7); | |
4185 | 108 return; |
109 } | |
6707 | 110 if (IMGFMT_IS_BGR(out_fmt)) { |
9171 | 111 if (IMGFMT_BGR_DEPTH(out_fmt) < 8 && !(out_fmt&128)) |
6707 | 112 mpi->bpp = IMGFMT_BGR_DEPTH(out_fmt); |
113 else | |
114 mpi->bpp=(IMGFMT_BGR_DEPTH(out_fmt)+7)&(~7); | |
4185 | 115 mpi->flags|=MP_IMGFLAG_SWAPPED; |
116 return; | |
117 } | |
118 mpi->flags|=MP_IMGFLAG_YUV; | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
119 mpi->num_planes=3; |
4185 | 120 switch(out_fmt){ |
121 case IMGFMT_I420: | |
122 case IMGFMT_IYUV: | |
123 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
124 case IMGFMT_YV12: | |
125 mpi->flags|=MP_IMGFLAG_PLANAR; | |
126 mpi->bpp=12; | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
127 mpi->chroma_width=(mpi->width>>1); |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
128 mpi->chroma_height=(mpi->height>>1); |
6539
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
129 mpi->chroma_x_shift=1; |
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
130 mpi->chroma_y_shift=1; |
4185 | 131 return; |
6525 | 132 case IMGFMT_IF09: |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
133 mpi->num_planes=4; |
6478 | 134 case IMGFMT_YVU9: |
135 mpi->flags|=MP_IMGFLAG_PLANAR; | |
136 mpi->bpp=9; | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
137 mpi->chroma_width=(mpi->width>>2); |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
138 mpi->chroma_height=(mpi->height>>2); |
6539
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
139 mpi->chroma_x_shift=2; |
79b536a37e40
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6538
diff
changeset
|
140 mpi->chroma_y_shift=2; |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
141 return; |
6863 | 142 case IMGFMT_444P: |
143 mpi->flags|=MP_IMGFLAG_PLANAR; | |
144 mpi->bpp=24; | |
145 mpi->chroma_width=(mpi->width); | |
146 mpi->chroma_height=(mpi->height); | |
147 mpi->chroma_x_shift=0; | |
148 mpi->chroma_y_shift=0; | |
149 return; | |
150 case IMGFMT_422P: | |
151 mpi->flags|=MP_IMGFLAG_PLANAR; | |
152 mpi->bpp=16; | |
153 mpi->chroma_width=(mpi->width>>1); | |
154 mpi->chroma_height=(mpi->height); | |
155 mpi->chroma_x_shift=1; | |
156 mpi->chroma_y_shift=0; | |
157 return; | |
158 case IMGFMT_411P: | |
159 mpi->flags|=MP_IMGFLAG_PLANAR; | |
160 mpi->bpp=12; | |
161 mpi->chroma_width=(mpi->width>>2); | |
162 mpi->chroma_height=(mpi->height); | |
163 mpi->chroma_x_shift=2; | |
164 mpi->chroma_y_shift=0; | |
165 return; | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
166 case IMGFMT_Y800: |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
167 case IMGFMT_Y8: |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
168 /* they're planar ones, but for easier handling use them as packed */ |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
169 // mpi->flags|=MP_IMGFLAG_PLANAR; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
170 mpi->bpp=8; |
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
171 mpi->num_planes=1; |
6478 | 172 return; |
4185 | 173 case IMGFMT_UYVY: |
174 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
175 case IMGFMT_YUY2: | |
176 mpi->bpp=16; | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
177 mpi->num_planes=1; |
5144 | 178 return; |
4185 | 179 } |
180 printf("mp_image: Unknown out_fmt: 0x%X\n",out_fmt); | |
181 mpi->bpp=0; | |
182 } | |
183 #endif | |
184 | |
185 static inline mp_image_t* new_mp_image(int w,int h){ | |
6911 | 186 mp_image_t* mpi=(mp_image_t*)malloc(sizeof(mp_image_t)); |
4185 | 187 if(!mpi) return NULL; // error! |
188 memset(mpi,0,sizeof(mp_image_t)); | |
189 mpi->width=mpi->w=w; | |
190 mpi->height=mpi->h=h; | |
191 return mpi; | |
192 } | |
4933 | 193 |
5737 | 194 static inline void free_mp_image(mp_image_t* mpi){ |
195 if(!mpi) return; | |
196 if(mpi->flags&MP_IMGFLAG_ALLOCATED){ | |
6538
afb4f3c107e7
better planar support, chroma subsampling support and Y8/Y800 support
alex
parents:
6525
diff
changeset
|
197 /* becouse we allocate the whole image in once */ |
5737 | 198 if(mpi->planes[0]) free(mpi->planes[0]); |
199 } | |
200 free(mpi); | |
201 } | |
202 | |
4933 | 203 #endif |