Mercurial > mplayer.hg
annotate mp_image.h @ 4962:993f274191ff
ACCEPT_WIDTH flag added
author | arpi |
---|---|
date | Wed, 06 Mar 2002 23:40:31 +0000 |
parents | 429994672d8c |
children | 643da7f45219 |
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 |
4185 | 27 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
28 // 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
|
29 // allocation. so we just export its buffer pointers: |
4186 | 30 #define MP_IMGTYPE_EXPORT 0 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
31 // codec requires a static WO buffer, but it does only partial updates later: |
4186 | 32 #define MP_IMGTYPE_STATIC 1 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
33 // codec just needs some WO memory, where it writes/copies the whole frame to: |
4186 | 34 #define MP_IMGTYPE_TEMP 2 |
4877
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
35 // I+P type, requires 2+ independent static R/W buffers |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
36 #define MP_IMGTYPE_IP 3 |
9d97874d8691
new flags added for direct rendering (libmpcodecs core)
arpi
parents:
4187
diff
changeset
|
37 // 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
|
38 #define MP_IMGTYPE_IPB 4 |
4186 | 39 |
4185 | 40 typedef struct mp_image_s { |
41 unsigned short flags; | |
4186 | 42 unsigned char type; |
43 unsigned char bpp; // bits/pixel. NOT depth! for RGB it will be n*8 | |
4185 | 44 unsigned int imgfmt; |
45 int width,height; // stored dimensions | |
46 int x,y,w,h; // visible dimensions | |
47 unsigned char* planes[3]; | |
48 unsigned int stride[3]; | |
49 int* qscale; | |
50 int qstride; | |
51 } mp_image_t; | |
52 | |
53 #ifdef IMGFMT_YUY2 | |
54 static inline void mp_image_setfmt(mp_image_t* mpi,unsigned int out_fmt){ | |
55 mpi->flags&=~(MP_IMGFLAG_PLANAR|MP_IMGFLAG_YUV|MP_IMGFLAG_SWAPPED); | |
4187 | 56 mpi->imgfmt=out_fmt; |
4185 | 57 if( (out_fmt&IMGFMT_RGB_MASK) == IMGFMT_RGB ){ |
4186 | 58 mpi->bpp=((out_fmt&255)+7)&(~7); |
4185 | 59 return; |
60 } | |
61 if( (out_fmt&IMGFMT_BGR_MASK) == IMGFMT_BGR ){ | |
4186 | 62 mpi->bpp=((out_fmt&255)+7)&(~7); |
4185 | 63 mpi->flags|=MP_IMGFLAG_SWAPPED; |
64 return; | |
65 } | |
66 mpi->flags|=MP_IMGFLAG_YUV; | |
67 switch(out_fmt){ | |
68 case IMGFMT_I420: | |
69 case IMGFMT_IYUV: | |
70 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
71 case IMGFMT_YV12: | |
72 mpi->flags|=MP_IMGFLAG_PLANAR; | |
73 mpi->bpp=12; | |
74 return; | |
75 case IMGFMT_UYVY: | |
76 mpi->flags|=MP_IMGFLAG_SWAPPED; | |
77 case IMGFMT_YUY2: | |
78 mpi->bpp=16; | |
79 return; | |
80 } | |
81 printf("mp_image: Unknown out_fmt: 0x%X\n",out_fmt); | |
82 mpi->bpp=0; | |
83 } | |
84 #endif | |
85 | |
86 static inline mp_image_t* new_mp_image(int w,int h){ | |
87 mp_image_t* mpi=malloc(sizeof(mp_image_t)); | |
88 if(!mpi) return NULL; // error! | |
89 memset(mpi,0,sizeof(mp_image_t)); | |
90 mpi->width=mpi->w=w; | |
91 mpi->height=mpi->h=h; | |
92 return mpi; | |
93 } | |
4933 | 94 |
95 #endif |