Mercurial > mplayer.hg
annotate libmpcodecs/mp_image.h @ 6525:0a7be46617d8
yvu9 and if09 support
author | alex |
---|---|
date | Sun, 23 Jun 2002 15:15:31 +0000 |
parents | feb97a44080b |
children | afb4f3c107e7 |
rev | line source |
---|---|
4933 | 1 #ifndef __MP_IMAGE_H |
2 #define __MP_IMAGE_H 1 | |
4185 | 3 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
4 // set if buffer content shouldn't be modified: |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
5 #define MP_IMGFLAG_PRESERVE 0x01 |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
6 // set if buffer content will be READED for next frame's MC: (I/P mpeg frames) |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
7 #define MP_IMGFLAG_READABLE 0x02 |
4185 | 8 // set if buffer is allocated (used in destination images): |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
9 #define MP_IMGFLAG_ALLOCATED 0x04 |
4185 | 10 // set if it's in video buffer/memory: |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
11 #define MP_IMGFLAG_DIRECT 0x08 |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
12 // codec accept any stride (>=width): |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
13 #define MP_IMGFLAG_ACCEPT_STRIDE 0x10 |
4962 | 14 // codec accept any width (width*bpp=stride) (>=width): |
15 #define MP_IMGFLAG_ACCEPT_WIDTH 0x20 | |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
16 // stride should be aligned to 16-byte (MB) boundary: |
4962 | 17 #define MP_IMGFLAG_ALIGNED_STRIDE 0x40 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
18 // codec uses drawing/rendering callbacks (draw_slice()-like thing, DR method 2) |
4962 | 19 #define MP_IMGFLAG_DRAW_CALLBACK 0x80 |
4185 | 20 |
21 // set if number of planes > 1 | |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
22 #define MP_IMGFLAG_PLANAR 0x100 |
4185 | 23 // set if it's YUV colorspace |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
24 #define MP_IMGFLAG_YUV 0x200 |
4185 | 25 // set if it's swapped plane/byteorder |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
26 #define MP_IMGFLAG_SWAPPED 0x400 |
4972 | 27 // type displayed (do not set this flag - it's for internal use!) |
28 #define MP_IMGFLAG_TYPE_DISPLAYED 0x800 | |
6478 | 29 // using palette for RGB data |
30 #define MP_IMGFLAG_TYPE_RGB_PALETTE 0x1000 | |
4185 | 31 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
32 // 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
|
33 // allocation. so we just export its buffer pointers: |
4186 | 34 #define MP_IMGTYPE_EXPORT 0 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
35 // codec requires a static WO buffer, but it does only partial updates later: |
4186 | 36 #define MP_IMGTYPE_STATIC 1 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
37 // codec just needs some WO memory, where it writes/copies the whole frame to: |
4186 | 38 #define MP_IMGTYPE_TEMP 2 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
39 // I+P type, requires 2+ independent static R/W buffers |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
40 #define MP_IMGTYPE_IP 3 |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
41 // 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
|
42 #define MP_IMGTYPE_IPB 4 |
4186 | 43 |
4185 | 44 typedef struct mp_image_s { |
45 unsigned short flags; | |
4186 | 46 unsigned char type; |
47 unsigned char bpp; // bits/pixel. NOT depth! for RGB it will be n*8 | |
4185 | 48 unsigned int imgfmt; |
49 int width,height; // stored dimensions | |
50 int x,y,w,h; // visible dimensions | |
51 unsigned char* planes[3]; | |
52 unsigned int stride[3]; | |
53 int* qscale; | |
54 int qstride; | |
55 } mp_image_t; | |
56 | |
57 #ifdef IMGFMT_YUY2 | |
58 static inline void mp_image_setfmt(mp_image_t* mpi,unsigned int out_fmt){ | |
59 mpi->flags&=~(MP_IMGFLAG_PLANAR|MP_IMGFLAG_YUV|MP_IMGFLAG_SWAPPED); | |
4187 | 60 mpi->imgfmt=out_fmt; |
4185 | 61 if( (out_fmt&IMGFMT_RGB_MASK) == IMGFMT_RGB ){ |
4186 | 62 mpi->bpp=((out_fmt&255)+7)&(~7); |
4185 | 63 return; |
64 } | |
65 if( (out_fmt&IMGFMT_BGR_MASK) == IMGFMT_BGR ){ | |
4186 | 66 mpi->bpp=((out_fmt&255)+7)&(~7); |
4185 | 67 mpi->flags|=MP_IMGFLAG_SWAPPED; |
68 return; | |
69 } | |
70 mpi->flags|=MP_IMGFLAG_YUV; | |
71 switch(out_fmt){ | |
72 case IMGFMT_I420: | |
73 case IMGFMT_IYUV: | |
74 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
75 case IMGFMT_YV12: | |
76 mpi->flags|=MP_IMGFLAG_PLANAR; | |
77 mpi->bpp=12; | |
78 return; | |
6525 | 79 case IMGFMT_IF09: |
6478 | 80 case IMGFMT_YVU9: |
81 mpi->flags|=MP_IMGFLAG_PLANAR; | |
82 mpi->bpp=9; | |
83 return; | |
4185 | 84 case IMGFMT_UYVY: |
85 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
86 case IMGFMT_YUY2: | |
87 mpi->bpp=16; | |
88 return; | |
5144 | 89 case IMGFMT_MPEGPES: |
90 mpi->bpp=0; | |
91 return; | |
4185 | 92 } |
93 printf("mp_image: Unknown out_fmt: 0x%X\n",out_fmt); | |
94 mpi->bpp=0; | |
95 } | |
96 #endif | |
97 | |
98 static inline mp_image_t* new_mp_image(int w,int h){ | |
99 mp_image_t* mpi=malloc(sizeof(mp_image_t)); | |
100 if(!mpi) return NULL; // error! | |
101 memset(mpi,0,sizeof(mp_image_t)); | |
102 mpi->width=mpi->w=w; | |
103 mpi->height=mpi->h=h; | |
104 return mpi; | |
105 } | |
4933 | 106 |
5737 | 107 static inline void free_mp_image(mp_image_t* mpi){ |
108 if(!mpi) return; | |
109 if(mpi->flags&MP_IMGFLAG_ALLOCATED){ | |
110 if(mpi->planes[0]) free(mpi->planes[0]); | |
111 } | |
112 free(mpi); | |
113 } | |
114 | |
4933 | 115 #endif |