1/*
2 *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
3 *
4 *  Use of this source code is governed by a BSD-style license
5 *  that can be found in the LICENSE file in the root of the source
6 *  tree. An additional intellectual property rights grant can be found
7 *  in the file PATENTS.  All contributing project authors may
8 *  be found in the AUTHORS file in the root of the source tree.
9 */
10
11
12/*!\file
13 * \brief Describes the vpx image descriptor and associated operations
14 *
15 */
16#ifndef VPX_VPX_IMAGE_H_
17#define VPX_VPX_IMAGE_H_
18
19#ifdef __cplusplus
20extern "C" {
21#endif
22
23  /*!\brief Current ABI version number
24   *
25   * \internal
26   * If this file is altered in any way that changes the ABI, this value
27   * must be bumped.  Examples include, but are not limited to, changing
28   * types, removing or reassigning enums, adding/removing/rearranging
29   * fields to structures
30   */
31#define VPX_IMAGE_ABI_VERSION (2) /**<\hideinitializer*/
32
33
34#define VPX_IMG_FMT_PLANAR     0x100  /**< Image is a planar format */
35#define VPX_IMG_FMT_UV_FLIP    0x200  /**< V plane precedes U plane in memory */
36#define VPX_IMG_FMT_HAS_ALPHA  0x400  /**< Image has an alpha channel component */
37
38
39  /*!\brief List of supported image formats */
40  typedef enum vpx_img_fmt {
41    VPX_IMG_FMT_NONE,
42    VPX_IMG_FMT_RGB24,   /**< 24 bit per pixel packed RGB */
43    VPX_IMG_FMT_RGB32,   /**< 32 bit per pixel packed 0RGB */
44    VPX_IMG_FMT_RGB565,  /**< 16 bit per pixel, 565 */
45    VPX_IMG_FMT_RGB555,  /**< 16 bit per pixel, 555 */
46    VPX_IMG_FMT_UYVY,    /**< UYVY packed YUV */
47    VPX_IMG_FMT_YUY2,    /**< YUYV packed YUV */
48    VPX_IMG_FMT_YVYU,    /**< YVYU packed YUV */
49    VPX_IMG_FMT_BGR24,   /**< 24 bit per pixel packed BGR */
50    VPX_IMG_FMT_RGB32_LE, /**< 32 bit packed BGR0 */
51    VPX_IMG_FMT_ARGB,     /**< 32 bit packed ARGB, alpha=255 */
52    VPX_IMG_FMT_ARGB_LE,  /**< 32 bit packed BGRA, alpha=255 */
53    VPX_IMG_FMT_RGB565_LE,  /**< 16 bit per pixel, gggbbbbb rrrrrggg */
54    VPX_IMG_FMT_RGB555_LE,  /**< 16 bit per pixel, gggbbbbb 0rrrrrgg */
55    VPX_IMG_FMT_YV12    = VPX_IMG_FMT_PLANAR | VPX_IMG_FMT_UV_FLIP | 1, /**< planar YVU */
56    VPX_IMG_FMT_I420    = VPX_IMG_FMT_PLANAR | 2,
57    VPX_IMG_FMT_VPXYV12 = VPX_IMG_FMT_PLANAR | VPX_IMG_FMT_UV_FLIP | 3, /** < planar 4:2:0 format with vpx color space */
58    VPX_IMG_FMT_VPXI420 = VPX_IMG_FMT_PLANAR | 4,
59    VPX_IMG_FMT_I422    = VPX_IMG_FMT_PLANAR | 5,
60    VPX_IMG_FMT_I444    = VPX_IMG_FMT_PLANAR | 6,
61    VPX_IMG_FMT_444A    = VPX_IMG_FMT_PLANAR | VPX_IMG_FMT_HAS_ALPHA | 7
62  } vpx_img_fmt_t; /**< alias for enum vpx_img_fmt */
63
64#if !defined(VPX_CODEC_DISABLE_COMPAT) || !VPX_CODEC_DISABLE_COMPAT
65#define IMG_FMT_PLANAR         VPX_IMG_FMT_PLANAR     /**< \deprecated Use #VPX_IMG_FMT_PLANAR */
66#define IMG_FMT_UV_FLIP        VPX_IMG_FMT_UV_FLIP    /**< \deprecated Use #VPX_IMG_FMT_UV_FLIP */
67#define IMG_FMT_HAS_ALPHA      VPX_IMG_FMT_HAS_ALPHA  /**< \deprecated Use #VPX_IMG_FMT_HAS_ALPHA */
68
69  /*!\brief Deprecated list of supported image formats
70   * \deprecated New code should use #vpx_img_fmt
71   */
72#define img_fmt   vpx_img_fmt
73  /*!\brief alias for enum img_fmt.
74   * \deprecated New code should use #vpx_img_fmt_t
75   */
76#define img_fmt_t vpx_img_fmt_t
77
78#define IMG_FMT_NONE       VPX_IMG_FMT_NONE       /**< \deprecated Use #VPX_IMG_FMT_NONE */
79#define IMG_FMT_RGB24      VPX_IMG_FMT_RGB24      /**< \deprecated Use #VPX_IMG_FMT_RGB24 */
80#define IMG_FMT_RGB32      VPX_IMG_FMT_RGB32      /**< \deprecated Use #VPX_IMG_FMT_RGB32 */
81#define IMG_FMT_RGB565     VPX_IMG_FMT_RGB565     /**< \deprecated Use #VPX_IMG_FMT_RGB565 */
82#define IMG_FMT_RGB555     VPX_IMG_FMT_RGB555     /**< \deprecated Use #VPX_IMG_FMT_RGB555 */
83#define IMG_FMT_UYVY       VPX_IMG_FMT_UYVY       /**< \deprecated Use #VPX_IMG_FMT_UYVY */
84#define IMG_FMT_YUY2       VPX_IMG_FMT_YUY2       /**< \deprecated Use #VPX_IMG_FMT_YUY2 */
85#define IMG_FMT_YVYU       VPX_IMG_FMT_YVYU       /**< \deprecated Use #VPX_IMG_FMT_YVYU */
86#define IMG_FMT_BGR24      VPX_IMG_FMT_BGR24      /**< \deprecated Use #VPX_IMG_FMT_BGR24 */
87#define IMG_FMT_RGB32_LE   VPX_IMG_FMT_RGB32_LE   /**< \deprecated Use #VPX_IMG_FMT_RGB32_LE */
88#define IMG_FMT_ARGB       VPX_IMG_FMT_ARGB       /**< \deprecated Use #VPX_IMG_FMT_ARGB */
89#define IMG_FMT_ARGB_LE    VPX_IMG_FMT_ARGB_LE    /**< \deprecated Use #VPX_IMG_FMT_ARGB_LE */
90#define IMG_FMT_RGB565_LE  VPX_IMG_FMT_RGB565_LE  /**< \deprecated Use #VPX_IMG_FMT_RGB565_LE */
91#define IMG_FMT_RGB555_LE  VPX_IMG_FMT_RGB555_LE  /**< \deprecated Use #VPX_IMG_FMT_RGB555_LE */
92#define IMG_FMT_YV12       VPX_IMG_FMT_YV12       /**< \deprecated Use #VPX_IMG_FMT_YV12 */
93#define IMG_FMT_I420       VPX_IMG_FMT_I420       /**< \deprecated Use #VPX_IMG_FMT_I420 */
94#define IMG_FMT_VPXYV12    VPX_IMG_FMT_VPXYV12    /**< \deprecated Use #VPX_IMG_FMT_VPXYV12 */
95#define IMG_FMT_VPXI420    VPX_IMG_FMT_VPXI420    /**< \deprecated Use #VPX_IMG_FMT_VPXI420 */
96#endif /* VPX_CODEC_DISABLE_COMPAT */
97
98  /**\brief Image Descriptor */
99  typedef struct vpx_image {
100    vpx_img_fmt_t fmt; /**< Image Format */
101
102    /* Image storage dimensions */
103    unsigned int  w;   /**< Stored image width */
104    unsigned int  h;   /**< Stored image height */
105
106    /* Image display dimensions */
107    unsigned int  d_w;   /**< Displayed image width */
108    unsigned int  d_h;   /**< Displayed image height */
109
110    /* Chroma subsampling info */
111    unsigned int  x_chroma_shift;   /**< subsampling order, X */
112    unsigned int  y_chroma_shift;   /**< subsampling order, Y */
113
114    /* Image data pointers. */
115#define VPX_PLANE_PACKED 0   /**< To be used for all packed formats */
116#define VPX_PLANE_Y      0   /**< Y (Luminance) plane */
117#define VPX_PLANE_U      1   /**< U (Chroma) plane */
118#define VPX_PLANE_V      2   /**< V (Chroma) plane */
119#define VPX_PLANE_ALPHA  3   /**< A (Transparency) plane */
120#if !defined(VPX_CODEC_DISABLE_COMPAT) || !VPX_CODEC_DISABLE_COMPAT
121#define PLANE_PACKED     VPX_PLANE_PACKED
122#define PLANE_Y          VPX_PLANE_Y
123#define PLANE_U          VPX_PLANE_U
124#define PLANE_V          VPX_PLANE_V
125#define PLANE_ALPHA      VPX_PLANE_ALPHA
126#endif
127    unsigned char *planes[4];  /**< pointer to the top left pixel for each plane */
128    int      stride[4];  /**< stride between rows for each plane */
129
130    int     bps; /**< bits per sample (for packed formats) */
131
132    /* The following member may be set by the application to associate data
133     * with this image.
134     */
135    void    *user_priv; /**< may be set by the application to associate data
136                         *   with this image. */
137
138    /* The following members should be treated as private. */
139    unsigned char *img_data;       /**< private */
140    int      img_data_owner; /**< private */
141    int      self_allocd;    /**< private */
142
143    void    *fb_priv; /**< Frame buffer data associated with the image. */
144
145    int      fb_index;
146  } vpx_image_t; /**< alias for struct vpx_image */
147
148  /**\brief Representation of a rectangle on a surface */
149  typedef struct vpx_image_rect {
150    unsigned int x; /**< leftmost column */
151    unsigned int y; /**< topmost row */
152    unsigned int w; /**< width */
153    unsigned int h; /**< height */
154  } vpx_image_rect_t; /**< alias for struct vpx_image_rect */
155
156  /*!\brief Open a descriptor, allocating storage for the underlying image
157   *
158   * Returns a descriptor for storing an image of the given format. The
159   * storage for the descriptor is allocated on the heap.
160   *
161   * \param[in]    img       Pointer to storage for descriptor. If this parameter
162   *                         is NULL, the storage for the descriptor will be
163   *                         allocated on the heap.
164   * \param[in]    fmt       Format for the image
165   * \param[in]    d_w       Width of the image
166   * \param[in]    d_h       Height of the image
167   * \param[in]    align     Alignment, in bytes, of the image buffer and
168   *                         each row in the image(stride).
169   *
170   * \return Returns a pointer to the initialized image descriptor. If the img
171   *         parameter is non-null, the value of the img parameter will be
172   *         returned.
173   */
174  vpx_image_t *vpx_img_alloc(vpx_image_t  *img,
175                             vpx_img_fmt_t fmt,
176                             unsigned int d_w,
177                             unsigned int d_h,
178                             unsigned int align);
179
180  /*!\brief Open a descriptor, using existing storage for the underlying image
181   *
182   * Returns a descriptor for storing an image of the given format. The
183   * storage for descriptor has been allocated elsewhere, and a descriptor is
184   * desired to "wrap" that storage.
185   *
186   * \param[in]    img       Pointer to storage for descriptor. If this parameter
187   *                         is NULL, the storage for the descriptor will be
188   *                         allocated on the heap.
189   * \param[in]    fmt       Format for the image
190   * \param[in]    d_w       Width of the image
191   * \param[in]    d_h       Height of the image
192   * \param[in]    align     Alignment, in bytes, of each row in the image.
193   * \param[in]    img_data  Storage to use for the image
194   *
195   * \return Returns a pointer to the initialized image descriptor. If the img
196   *         parameter is non-null, the value of the img parameter will be
197   *         returned.
198   */
199  vpx_image_t *vpx_img_wrap(vpx_image_t  *img,
200                            vpx_img_fmt_t fmt,
201                            unsigned int d_w,
202                            unsigned int d_h,
203                            unsigned int align,
204                            unsigned char      *img_data);
205
206
207  /*!\brief Set the rectangle identifying the displayed portion of the image
208   *
209   * Updates the displayed rectangle (aka viewport) on the image surface to
210   * match the specified coordinates and size.
211   *
212   * \param[in]    img       Image descriptor
213   * \param[in]    x         leftmost column
214   * \param[in]    y         topmost row
215   * \param[in]    w         width
216   * \param[in]    h         height
217   *
218   * \return 0 if the requested rectangle is valid, nonzero otherwise.
219   */
220  int vpx_img_set_rect(vpx_image_t  *img,
221                       unsigned int  x,
222                       unsigned int  y,
223                       unsigned int  w,
224                       unsigned int  h);
225
226
227  /*!\brief Flip the image vertically (top for bottom)
228   *
229   * Adjusts the image descriptor's pointers and strides to make the image
230   * be referenced upside-down.
231   *
232   * \param[in]    img       Image descriptor
233   */
234  void vpx_img_flip(vpx_image_t *img);
235
236  /*!\brief Close an image descriptor
237   *
238   * Frees all allocated storage associated with an image descriptor.
239   *
240   * \param[in]    img       Image descriptor
241   */
242  void vpx_img_free(vpx_image_t *img);
243
244#ifdef __cplusplus
245}  // extern "C"
246#endif
247
248#endif  // VPX_VPX_IMAGE_H_
249