| 1 | /***************************************************************************** |
| 2 | * vlc_es.h: Elementary stream formats descriptions |
| 3 | ***************************************************************************** |
| 4 | * Copyright (C) 1999-2012 VLC authors and VideoLAN |
| 5 | * $Id: 3c8e04e1b15740166df2e0b2d9a651ffb2c5bc2f $ |
| 6 | * |
| 7 | * Authors: Laurent Aimar <fenrir@via.ecp.fr> |
| 8 | * |
| 9 | * This program is free software; you can redistribute it and/or modify it |
| 10 | * under the terms of the GNU Lesser General Public License as published by |
| 11 | * the Free Software Foundation; either version 2.1 of the License, or |
| 12 | * (at your option) any later version. |
| 13 | * |
| 14 | * This program is distributed in the hope that it will be useful, |
| 15 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| 17 | * GNU Lesser General Public License for more details. |
| 18 | * |
| 19 | * You should have received a copy of the GNU Lesser General Public License |
| 20 | * along with this program; if not, write to the Free Software Foundation, |
| 21 | * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA. |
| 22 | *****************************************************************************/ |
| 23 | |
| 24 | #ifndef VLC_ES_H |
| 25 | #define VLC_ES_H 1 |
| 26 | |
| 27 | #include <vlc_common.h> |
| 28 | #include <vlc_fourcc.h> |
| 29 | #include <vlc_text_style.h> |
| 30 | #include <vlc_viewpoint.h> |
| 31 | |
| 32 | /** |
| 33 | * \file |
| 34 | * This file defines the elementary streams format types |
| 35 | */ |
| 36 | |
| 37 | /** |
| 38 | * video palette data |
| 39 | * \see video_format_t |
| 40 | * \see subs_format_t |
| 41 | */ |
| 42 | #define VIDEO_PALETTE_COLORS_MAX 256 |
| 43 | |
| 44 | struct video_palette_t |
| 45 | { |
| 46 | int i_entries; /**< to keep the compatibility with libavcodec's palette */ |
| 47 | uint8_t palette[VIDEO_PALETTE_COLORS_MAX][4]; /**< 4-byte RGBA/YUVA palette */ |
| 48 | }; |
| 49 | |
| 50 | /** |
| 51 | * audio replay gain description |
| 52 | */ |
| 53 | #define AUDIO_REPLAY_GAIN_MAX (2) |
| 54 | #define AUDIO_REPLAY_GAIN_TRACK (0) |
| 55 | #define AUDIO_REPLAY_GAIN_ALBUM (1) |
| 56 | typedef struct |
| 57 | { |
| 58 | /* true if we have the peak value */ |
| 59 | bool pb_peak[AUDIO_REPLAY_GAIN_MAX]; |
| 60 | /* peak value where 1.0 means full sample value */ |
| 61 | float pf_peak[AUDIO_REPLAY_GAIN_MAX]; |
| 62 | |
| 63 | /* true if we have the gain value */ |
| 64 | bool pb_gain[AUDIO_REPLAY_GAIN_MAX]; |
| 65 | /* gain value in dB */ |
| 66 | float pf_gain[AUDIO_REPLAY_GAIN_MAX]; |
| 67 | } audio_replay_gain_t; |
| 68 | |
| 69 | |
| 70 | /** |
| 71 | * Audio channel type |
| 72 | */ |
| 73 | typedef enum audio_channel_type_t |
| 74 | { |
| 75 | AUDIO_CHANNEL_TYPE_BITMAP, |
| 76 | AUDIO_CHANNEL_TYPE_AMBISONICS, |
| 77 | } audio_channel_type_t; |
| 78 | |
| 79 | /** |
| 80 | * audio format description |
| 81 | */ |
| 82 | struct audio_format_t |
| 83 | { |
| 84 | vlc_fourcc_t i_format; /**< audio format fourcc */ |
| 85 | unsigned int i_rate; /**< audio sample-rate */ |
| 86 | |
| 87 | /* Describes the channels configuration of the samples (ie. number of |
| 88 | * channels which are available in the buffer, and positions). */ |
| 89 | uint16_t i_physical_channels; |
| 90 | |
| 91 | /* Describes the chan mode, either set from the input |
| 92 | * (demux/codec/packetizer) or overridden by the user, used by audio |
| 93 | * filters. */ |
| 94 | uint16_t i_chan_mode; |
| 95 | |
| 96 | /* Channel type */ |
| 97 | audio_channel_type_t channel_type; |
| 98 | |
| 99 | /* Optional - for A/52, SPDIF and DTS types : */ |
| 100 | /* Bytes used by one compressed frame, depends on bitrate. */ |
| 101 | unsigned int i_bytes_per_frame; |
| 102 | |
| 103 | /* Number of sampleframes contained in one compressed frame. */ |
| 104 | unsigned int i_frame_length; |
| 105 | /* Please note that it may be completely arbitrary - buffers are not |
| 106 | * obliged to contain a integral number of so-called "frames". It's |
| 107 | * just here for the division : |
| 108 | * buffer_size = i_nb_samples * i_bytes_per_frame / i_frame_length |
| 109 | */ |
| 110 | |
| 111 | /* FIXME ? (used by the codecs) */ |
| 112 | unsigned i_bitspersample; |
| 113 | unsigned i_blockalign; |
| 114 | uint8_t i_channels; /* must be <=32 */ |
| 115 | }; |
| 116 | |
| 117 | /* Values available for audio channels */ |
| 118 | #define AOUT_CHAN_CENTER 0x1 |
| 119 | #define AOUT_CHAN_LEFT 0x2 |
| 120 | #define AOUT_CHAN_RIGHT 0x4 |
| 121 | #define AOUT_CHAN_REARCENTER 0x10 |
| 122 | #define AOUT_CHAN_REARLEFT 0x20 |
| 123 | #define AOUT_CHAN_REARRIGHT 0x40 |
| 124 | #define AOUT_CHAN_MIDDLELEFT 0x100 |
| 125 | #define AOUT_CHAN_MIDDLERIGHT 0x200 |
| 126 | #define AOUT_CHAN_LFE 0x1000 |
| 127 | |
| 128 | #define AOUT_CHANS_FRONT (AOUT_CHAN_LEFT | AOUT_CHAN_RIGHT) |
| 129 | #define AOUT_CHANS_MIDDLE (AOUT_CHAN_MIDDLELEFT | AOUT_CHAN_MIDDLERIGHT) |
| 130 | #define AOUT_CHANS_REAR (AOUT_CHAN_REARLEFT | AOUT_CHAN_REARRIGHT) |
| 131 | #define AOUT_CHANS_CENTER (AOUT_CHAN_CENTER | AOUT_CHAN_REARCENTER) |
| 132 | |
| 133 | #define AOUT_CHANS_STEREO AOUT_CHANS_2_0 |
| 134 | #define AOUT_CHANS_2_0 (AOUT_CHANS_FRONT) |
| 135 | #define AOUT_CHANS_2_1 (AOUT_CHANS_FRONT | AOUT_CHAN_LFE) |
| 136 | #define AOUT_CHANS_3_0 (AOUT_CHANS_FRONT | AOUT_CHAN_CENTER) |
| 137 | #define AOUT_CHANS_3_1 (AOUT_CHANS_3_0 | AOUT_CHAN_LFE) |
| 138 | #define AOUT_CHANS_4_0 (AOUT_CHANS_FRONT | AOUT_CHANS_REAR) |
| 139 | #define AOUT_CHANS_4_1 (AOUT_CHANS_4_0 | AOUT_CHAN_LFE) |
| 140 | #define AOUT_CHANS_5_0 (AOUT_CHANS_4_0 | AOUT_CHAN_CENTER) |
| 141 | #define AOUT_CHANS_5_1 (AOUT_CHANS_5_0 | AOUT_CHAN_LFE) |
| 142 | #define AOUT_CHANS_6_0 (AOUT_CHANS_4_0 | AOUT_CHANS_MIDDLE) |
| 143 | #define AOUT_CHANS_7_0 (AOUT_CHANS_6_0 | AOUT_CHAN_CENTER) |
| 144 | #define AOUT_CHANS_7_1 (AOUT_CHANS_5_1 | AOUT_CHANS_MIDDLE) |
| 145 | #define AOUT_CHANS_8_1 (AOUT_CHANS_7_1 | AOUT_CHAN_REARCENTER) |
| 146 | |
| 147 | #define AOUT_CHANS_4_0_MIDDLE (AOUT_CHANS_FRONT | AOUT_CHANS_MIDDLE) |
| 148 | #define AOUT_CHANS_4_CENTER_REAR (AOUT_CHANS_FRONT | AOUT_CHANS_CENTER) |
| 149 | #define AOUT_CHANS_5_0_MIDDLE (AOUT_CHANS_4_0_MIDDLE | AOUT_CHAN_CENTER) |
| 150 | #define AOUT_CHANS_6_1_MIDDLE (AOUT_CHANS_5_0_MIDDLE | AOUT_CHAN_REARCENTER | AOUT_CHAN_LFE) |
| 151 | |
| 152 | /* Maximum number of mapped channels (or the maximum of bits set in |
| 153 | * i_physical_channels) */ |
| 154 | #define AOUT_CHAN_MAX 9 |
| 155 | /* Maximum number of unmapped channels */ |
| 156 | #define INPUT_CHAN_MAX 64 |
| 157 | |
| 158 | /* Values available for i_chan_mode only */ |
| 159 | #define AOUT_CHANMODE_DUALMONO 0x1 |
| 160 | #define AOUT_CHANMODE_DOLBYSTEREO 0x2 |
| 161 | |
| 162 | /** |
| 163 | * Picture orientation. |
| 164 | */ |
| 165 | typedef enum video_orientation_t |
| 166 | { |
| 167 | ORIENT_TOP_LEFT = 0, /**< Top line represents top, left column left. */ |
| 168 | ORIENT_TOP_RIGHT, /**< Flipped horizontally */ |
| 169 | ORIENT_BOTTOM_LEFT, /**< Flipped vertically */ |
| 170 | ORIENT_BOTTOM_RIGHT, /**< Rotated 180 degrees */ |
| 171 | ORIENT_LEFT_TOP, /**< Transposed */ |
| 172 | ORIENT_LEFT_BOTTOM, /**< Rotated 90 degrees clockwise */ |
| 173 | ORIENT_RIGHT_TOP, /**< Rotated 90 degrees anti-clockwise */ |
| 174 | ORIENT_RIGHT_BOTTOM, /**< Anti-transposed */ |
| 175 | |
| 176 | ORIENT_NORMAL = ORIENT_TOP_LEFT, |
| 177 | ORIENT_TRANSPOSED = ORIENT_LEFT_TOP, |
| 178 | ORIENT_ANTI_TRANSPOSED = ORIENT_RIGHT_BOTTOM, |
| 179 | ORIENT_HFLIPPED = ORIENT_TOP_RIGHT, |
| 180 | ORIENT_VFLIPPED = ORIENT_BOTTOM_LEFT, |
| 181 | ORIENT_ROTATED_180 = ORIENT_BOTTOM_RIGHT, |
| 182 | ORIENT_ROTATED_270 = ORIENT_LEFT_BOTTOM, |
| 183 | ORIENT_ROTATED_90 = ORIENT_RIGHT_TOP, |
| 184 | } video_orientation_t; |
| 185 | /** Convert EXIF orientation to enum video_orientation_t */ |
| 186 | #define ORIENT_FROM_EXIF(exif) ((0x57642310U >> (4 * ((exif) - 1))) & 7) |
| 187 | /** Convert enum video_orientation_t to EXIF */ |
| 188 | #define ORIENT_TO_EXIF(orient) ((0x76853421U >> (4 * (orient))) & 15) |
| 189 | /** If the orientation is natural or mirrored */ |
| 190 | #define ORIENT_IS_MIRROR(orient) parity(orient) |
| 191 | /** If the orientation swaps dimensions */ |
| 192 | #define ORIENT_IS_SWAP(orient) (((orient) & 4) != 0) |
| 193 | /** Applies horizontal flip to an orientation */ |
| 194 | #define ORIENT_HFLIP(orient) ((orient) ^ 1) |
| 195 | /** Applies vertical flip to an orientation */ |
| 196 | #define ORIENT_VFLIP(orient) ((orient) ^ 2) |
| 197 | /** Applies horizontal flip to an orientation */ |
| 198 | #define ORIENT_ROTATE_180(orient) ((orient) ^ 3) |
| 199 | |
| 200 | typedef enum video_transform_t |
| 201 | { |
| 202 | TRANSFORM_IDENTITY = ORIENT_NORMAL, |
| 203 | TRANSFORM_HFLIP = ORIENT_HFLIPPED, |
| 204 | TRANSFORM_VFLIP = ORIENT_VFLIPPED, |
| 205 | TRANSFORM_R180 = ORIENT_ROTATED_180, |
| 206 | TRANSFORM_R270 = ORIENT_ROTATED_270, |
| 207 | TRANSFORM_R90 = ORIENT_ROTATED_90, |
| 208 | TRANSFORM_TRANSPOSE = ORIENT_TRANSPOSED, |
| 209 | TRANSFORM_ANTI_TRANSPOSE = ORIENT_ANTI_TRANSPOSED |
| 210 | } video_transform_t; |
| 211 | |
| 212 | typedef enum video_multiview_mode_t |
| 213 | { |
| 214 | /* No stereoscopy: 2D picture. */ |
| 215 | MULTIVIEW_2D = 0, |
| 216 | |
| 217 | /* Side-by-side with left eye first. */ |
| 218 | MULTIVIEW_STEREO_SBS, |
| 219 | |
| 220 | /* Top-bottom with left eye first. */ |
| 221 | MULTIVIEW_STEREO_TB, |
| 222 | |
| 223 | /* Row sequential with left eye first. */ |
| 224 | MULTIVIEW_STEREO_ROW, |
| 225 | |
| 226 | /* Column sequential with left eye first. */ |
| 227 | MULTIVIEW_STEREO_COL, |
| 228 | |
| 229 | /* Frame sequential with left eye first. */ |
| 230 | MULTIVIEW_STEREO_FRAME, |
| 231 | |
| 232 | /* Checkerboard pattern with left eye first. */ |
| 233 | MULTIVIEW_STEREO_CHECKERBOARD, |
| 234 | } video_multiview_mode_t; |
| 235 | |
| 236 | /** |
| 237 | * Video projection mode. |
| 238 | */ |
| 239 | typedef enum video_projection_mode_t |
| 240 | { |
| 241 | PROJECTION_MODE_RECTANGULAR = 0, |
| 242 | PROJECTION_MODE_EQUIRECTANGULAR, |
| 243 | |
| 244 | PROJECTION_MODE_CUBEMAP_LAYOUT_STANDARD = 0x100, |
| 245 | } video_projection_mode_t; |
| 246 | |
| 247 | /** |
| 248 | * Video color primaries (a.k.a. chromacities) |
| 249 | */ |
| 250 | typedef enum video_color_primaries_t |
| 251 | { |
| 252 | COLOR_PRIMARIES_UNDEF, |
| 253 | COLOR_PRIMARIES_BT601_525, |
| 254 | COLOR_PRIMARIES_BT601_625, |
| 255 | COLOR_PRIMARIES_BT709, |
| 256 | COLOR_PRIMARIES_BT2020, |
| 257 | COLOR_PRIMARIES_DCI_P3, |
| 258 | COLOR_PRIMARIES_FCC1953, |
| 259 | #define COLOR_PRIMARIES_SRGB COLOR_PRIMARIES_BT709 |
| 260 | #define COLOR_PRIMARIES_SMTPE_170 COLOR_PRIMARIES_BT601_525 |
| 261 | #define COLOR_PRIMARIES_SMTPE_240 COLOR_PRIMARIES_BT601_525 /* Only differs from 1e10-4 in white Y */ |
| 262 | #define COLOR_PRIMARIES_SMTPE_RP145 COLOR_PRIMARIES_BT601_525 |
| 263 | #define COLOR_PRIMARIES_EBU_3213 COLOR_PRIMARIES_BT601_625 |
| 264 | #define COLOR_PRIMARIES_BT470_BG COLOR_PRIMARIES_BT601_625 |
| 265 | #define COLOR_PRIMARIES_BT470_M COLOR_PRIMARIES_FCC1953 |
| 266 | #define COLOR_PRIMARIES_MAX COLOR_PRIMARIES_FCC1953 |
| 267 | } video_color_primaries_t; |
| 268 | |
| 269 | /** |
| 270 | * Video transfer functions |
| 271 | */ |
| 272 | typedef enum video_transfer_func_t |
| 273 | { |
| 274 | TRANSFER_FUNC_UNDEF, |
| 275 | TRANSFER_FUNC_LINEAR, |
| 276 | TRANSFER_FUNC_SRGB /*< Gamma 2.2 */, |
| 277 | TRANSFER_FUNC_BT470_BG, |
| 278 | TRANSFER_FUNC_BT470_M, |
| 279 | TRANSFER_FUNC_BT709, |
| 280 | TRANSFER_FUNC_SMPTE_ST2084, |
| 281 | TRANSFER_FUNC_SMPTE_240, |
| 282 | TRANSFER_FUNC_HLG, |
| 283 | #define TRANSFER_FUNC_BT2020 TRANSFER_FUNC_BT709 |
| 284 | #define TRANSFER_FUNC_SMPTE_170 TRANSFER_FUNC_BT709 |
| 285 | #define TRANSFER_FUNC_SMPTE_274 TRANSFER_FUNC_BT709 |
| 286 | #define TRANSFER_FUNC_SMPTE_293 TRANSFER_FUNC_BT709 |
| 287 | #define TRANSFER_FUNC_SMPTE_296 TRANSFER_FUNC_BT709 |
| 288 | #define TRANSFER_FUNC_ARIB_B67 TRANSFER_FUNC_HLG |
| 289 | #define TRANSFER_FUNC_MAX TRANSFER_FUNC_HLG |
| 290 | } video_transfer_func_t; |
| 291 | |
| 292 | /** |
| 293 | * Video color space (i.e. YCbCr matrices) |
| 294 | */ |
| 295 | typedef enum video_color_space_t |
| 296 | { |
| 297 | COLOR_SPACE_UNDEF, |
| 298 | COLOR_SPACE_BT601, |
| 299 | COLOR_SPACE_BT709, |
| 300 | COLOR_SPACE_BT2020, |
| 301 | #define COLOR_SPACE_SRGB COLOR_SPACE_BT709 |
| 302 | #define COLOR_SPACE_SMPTE_170 COLOR_SPACE_BT601 |
| 303 | #define COLOR_SPACE_SMPTE_240 COLOR_SPACE_SMPTE_170 |
| 304 | #define COLOR_SPACE_MAX COLOR_SPACE_BT2020 |
| 305 | } video_color_space_t; |
| 306 | |
| 307 | /** |
| 308 | * Video chroma location |
| 309 | */ |
| 310 | typedef enum video_chroma_location_t |
| 311 | { |
| 312 | CHROMA_LOCATION_UNDEF, |
| 313 | CHROMA_LOCATION_LEFT, /*< Most common in MPEG-2 Video, H.264/265 */ |
| 314 | CHROMA_LOCATION_CENTER, /*< Most common in MPEG-1 Video, JPEG */ |
| 315 | CHROMA_LOCATION_TOP_LEFT, |
| 316 | CHROMA_LOCATION_TOP_CENTER, |
| 317 | CHROMA_LOCATION_BOTTOM_LEFT, |
| 318 | CHROMA_LOCATION_BOTTOM_CENTER, |
| 319 | #define CHROMA_LOCATION_MAX CHROMA_LOCATION_BOTTOM_CENTER |
| 320 | } video_chroma_location_t; |
| 321 | |
| 322 | /** |
| 323 | * video format description |
| 324 | */ |
| 325 | struct video_format_t |
| 326 | { |
| 327 | vlc_fourcc_t i_chroma; /**< picture chroma */ |
| 328 | |
| 329 | unsigned int i_width; /**< picture width */ |
| 330 | unsigned int i_height; /**< picture height */ |
| 331 | unsigned int i_x_offset; /**< start offset of visible area */ |
| 332 | unsigned int i_y_offset; /**< start offset of visible area */ |
| 333 | unsigned int i_visible_width; /**< width of visible area */ |
| 334 | unsigned int i_visible_height; /**< height of visible area */ |
| 335 | |
| 336 | unsigned int i_bits_per_pixel; /**< number of bits per pixel */ |
| 337 | |
| 338 | unsigned int i_sar_num; /**< sample/pixel aspect ratio */ |
| 339 | unsigned int i_sar_den; |
| 340 | |
| 341 | unsigned int i_frame_rate; /**< frame rate numerator */ |
| 342 | unsigned int i_frame_rate_base; /**< frame rate denominator */ |
| 343 | |
| 344 | uint32_t i_rmask, i_gmask, i_bmask; /**< color masks for RGB chroma */ |
| 345 | int i_rrshift, i_lrshift; |
| 346 | int i_rgshift, i_lgshift; |
| 347 | int i_rbshift, i_lbshift; |
| 348 | video_palette_t *p_palette; /**< video palette from demuxer */ |
| 349 | video_orientation_t orientation; /**< picture orientation */ |
| 350 | video_color_primaries_t primaries; /**< color primaries */ |
| 351 | video_transfer_func_t transfer; /**< transfer function */ |
| 352 | video_color_space_t space; /**< YCbCr color space */ |
| 353 | bool b_color_range_full; /**< 0-255 instead of 16-235 */ |
| 354 | video_chroma_location_t chroma_location; /**< YCbCr chroma location */ |
| 355 | |
| 356 | video_multiview_mode_t multiview_mode; /** Multiview mode, 2D, 3D */ |
| 357 | |
| 358 | video_projection_mode_t projection_mode; /**< projection mode */ |
| 359 | vlc_viewpoint_t pose; |
| 360 | struct { |
| 361 | /* similar to SMPTE ST 2086 mastering display color volume */ |
| 362 | uint16_t primaries[3*2]; /* G,B,R / x,y */ |
| 363 | uint16_t white_point[2]; /* x,y */ |
| 364 | uint32_t max_luminance; |
| 365 | uint32_t min_luminance; |
| 366 | } mastering; |
| 367 | struct { |
| 368 | /* similar to CTA-861.3 content light level */ |
| 369 | uint16_t MaxCLL; /* max content light level */ |
| 370 | uint16_t MaxFALL; /* max frame average light level */ |
| 371 | } lighting; |
| 372 | uint32_t i_cubemap_padding; /**< padding in pixels of the cube map faces */ |
| 373 | }; |
| 374 | |
| 375 | /** |
| 376 | * Initialize a video_format_t structure with chroma 'i_chroma' |
| 377 | * \param p_src pointer to video_format_t structure |
| 378 | * \param i_chroma chroma value to use |
| 379 | */ |
| 380 | static inline void video_format_Init( video_format_t *p_src, vlc_fourcc_t i_chroma ) |
| 381 | { |
| 382 | memset( s: p_src, c: 0, n: sizeof( video_format_t ) ); |
| 383 | p_src->i_chroma = i_chroma; |
| 384 | vlc_viewpoint_init( p_vp: &p_src->pose ); |
| 385 | } |
| 386 | |
| 387 | /** |
| 388 | * Copy video_format_t including the palette |
| 389 | * \param p_dst video_format_t to copy to |
| 390 | * \param p_src video_format_t to copy from |
| 391 | */ |
| 392 | static inline int video_format_Copy( video_format_t *p_dst, const video_format_t *p_src ) |
| 393 | { |
| 394 | memcpy( dest: p_dst, src: p_src, n: sizeof( *p_dst ) ); |
| 395 | if( p_src->p_palette ) |
| 396 | { |
| 397 | p_dst->p_palette = (video_palette_t *) malloc( size: sizeof( video_palette_t ) ); |
| 398 | if( !p_dst->p_palette ) |
| 399 | return VLC_ENOMEM; |
| 400 | memcpy( dest: p_dst->p_palette, src: p_src->p_palette, n: sizeof( *p_dst->p_palette ) ); |
| 401 | } |
| 402 | return VLC_SUCCESS; |
| 403 | } |
| 404 | |
| 405 | static inline void video_format_AdjustColorSpace( video_format_t *p_fmt ) |
| 406 | { |
| 407 | if ( p_fmt->primaries == COLOR_PRIMARIES_UNDEF ) |
| 408 | { |
| 409 | if ( p_fmt->i_visible_height > 576 ) // HD |
| 410 | p_fmt->primaries = COLOR_PRIMARIES_BT709; |
| 411 | else if ( p_fmt->i_visible_height > 525 ) // PAL |
| 412 | p_fmt->primaries = COLOR_PRIMARIES_BT601_625; |
| 413 | else |
| 414 | p_fmt->primaries = COLOR_PRIMARIES_BT601_525; |
| 415 | } |
| 416 | |
| 417 | if ( p_fmt->transfer == TRANSFER_FUNC_UNDEF ) |
| 418 | { |
| 419 | if ( p_fmt->i_visible_height > 576 ) // HD |
| 420 | p_fmt->transfer = TRANSFER_FUNC_BT709; |
| 421 | else |
| 422 | p_fmt->transfer = TRANSFER_FUNC_SRGB; |
| 423 | } |
| 424 | |
| 425 | if ( p_fmt->space == COLOR_SPACE_UNDEF ) |
| 426 | { |
| 427 | if ( p_fmt->i_visible_height > 576 ) // HD |
| 428 | p_fmt->space = COLOR_SPACE_BT709; |
| 429 | else |
| 430 | p_fmt->space = COLOR_SPACE_BT601; |
| 431 | } |
| 432 | } |
| 433 | |
| 434 | /** |
| 435 | * Cleanup and free palette of this video_format_t |
| 436 | * \param p_src video_format_t structure to clean |
| 437 | */ |
| 438 | static inline void video_format_Clean( video_format_t *p_src ) |
| 439 | { |
| 440 | free( ptr: p_src->p_palette ); |
| 441 | memset( s: p_src, c: 0, n: sizeof( video_format_t ) ); |
| 442 | } |
| 443 | |
| 444 | /** |
| 445 | * It will fill up a video_format_t using the given arguments. |
| 446 | * Note that the video_format_t must already be initialized. |
| 447 | */ |
| 448 | VLC_API void video_format_Setup( video_format_t *, vlc_fourcc_t i_chroma, |
| 449 | int i_width, int i_height, int i_visible_width, int i_visible_height, |
| 450 | int i_sar_num, int i_sar_den ); |
| 451 | |
| 452 | /** |
| 453 | * It will copy the crop properties from a video_format_t to another. |
| 454 | */ |
| 455 | VLC_API void video_format_CopyCrop( video_format_t *, const video_format_t * ); |
| 456 | |
| 457 | /** |
| 458 | * It will compute the crop/ar properties when scaling. |
| 459 | */ |
| 460 | VLC_API void video_format_ScaleCropAr( video_format_t *, const video_format_t * ); |
| 461 | |
| 462 | /** |
| 463 | * This function "normalizes" the formats orientation, by switching the a/r according to the orientation, |
| 464 | * producing a format whose orientation is ORIENT_NORMAL. It makes a shallow copy (pallette is not alloc'ed). |
| 465 | */ |
| 466 | VLC_API void video_format_ApplyRotation(video_format_t * /*restrict*/ out, |
| 467 | const video_format_t *in); |
| 468 | |
| 469 | /** |
| 470 | * This function applies the transform operation to fmt. |
| 471 | */ |
| 472 | VLC_API void video_format_TransformBy(video_format_t *fmt, video_transform_t transform); |
| 473 | |
| 474 | /** |
| 475 | * This function applies the transforms necessary to fmt so that the resulting fmt |
| 476 | * has the dst_orientation. |
| 477 | */ |
| 478 | VLC_API void video_format_TransformTo(video_format_t *fmt, video_orientation_t dst_orientation); |
| 479 | |
| 480 | /** |
| 481 | * Returns the operation required to transform src into dst. |
| 482 | */ |
| 483 | VLC_API video_transform_t video_format_GetTransform(video_orientation_t src, video_orientation_t dst); |
| 484 | |
| 485 | /** |
| 486 | * This function will check if the first video format is similar |
| 487 | * to the second one. |
| 488 | */ |
| 489 | VLC_API bool video_format_IsSimilar( const video_format_t *, const video_format_t * ); |
| 490 | |
| 491 | /** |
| 492 | * It prints details about the given video_format_t |
| 493 | */ |
| 494 | VLC_API void video_format_Print( vlc_object_t *, const char *, const video_format_t * ); |
| 495 | |
| 496 | |
| 497 | static inline video_transform_t transform_Inverse( video_transform_t transform ) |
| 498 | { |
| 499 | switch ( transform ) { |
| 500 | case TRANSFORM_R90: |
| 501 | return TRANSFORM_R270; |
| 502 | case TRANSFORM_R270: |
| 503 | return TRANSFORM_R90; |
| 504 | default: |
| 505 | return transform; |
| 506 | } |
| 507 | } |
| 508 | /** |
| 509 | * subtitles format description |
| 510 | */ |
| 511 | struct subs_format_t |
| 512 | { |
| 513 | /* the character encoding of the text of the subtitle. |
| 514 | * all gettext recognized shorts can be used */ |
| 515 | char *psz_encoding; |
| 516 | |
| 517 | |
| 518 | int i_x_origin; /**< x coordinate of the subtitle. 0 = left */ |
| 519 | int i_y_origin; /**< y coordinate of the subtitle. 0 = top */ |
| 520 | |
| 521 | struct |
| 522 | { |
| 523 | /* */ |
| 524 | uint32_t palette[16+1]; /* CLUT Palette AYVU */ |
| 525 | |
| 526 | /* the width of the original movie the spu was extracted from */ |
| 527 | int i_original_frame_width; |
| 528 | /* the height of the original movie the spu was extracted from */ |
| 529 | int i_original_frame_height; |
| 530 | } spu; |
| 531 | |
| 532 | struct |
| 533 | { |
| 534 | int i_id; |
| 535 | } dvb; |
| 536 | struct |
| 537 | { |
| 538 | int i_magazine; |
| 539 | int i_page; |
| 540 | } teletext; |
| 541 | struct |
| 542 | { |
| 543 | uint8_t i_channel; |
| 544 | /* Reorder depth of transport video, -1 for no reordering */ |
| 545 | int i_reorder_depth; |
| 546 | } cc; |
| 547 | |
| 548 | text_style_t *p_style; /* Default styles to use */ |
| 549 | }; |
| 550 | |
| 551 | #define SPU_PALETTE_DEFINED 0xbeefbeef |
| 552 | |
| 553 | /** |
| 554 | * ES language definition |
| 555 | */ |
| 556 | typedef struct |
| 557 | { |
| 558 | char *; |
| 559 | char *; |
| 560 | } ; |
| 561 | |
| 562 | /** ES Categories */ |
| 563 | enum es_format_category_e |
| 564 | { |
| 565 | UNKNOWN_ES = 0x00, |
| 566 | VIDEO_ES, |
| 567 | AUDIO_ES, |
| 568 | SPU_ES, |
| 569 | DATA_ES, |
| 570 | }; |
| 571 | #define ES_CATEGORY_COUNT (DATA_ES + 1) |
| 572 | |
| 573 | /** |
| 574 | * ES format definition |
| 575 | */ |
| 576 | #define ES_PRIORITY_NOT_SELECTABLE -2 |
| 577 | #define ES_PRIORITY_NOT_DEFAULTABLE -1 |
| 578 | #define ES_PRIORITY_SELECTABLE_MIN 0 |
| 579 | #define ES_PRIORITY_MIN ES_PRIORITY_NOT_SELECTABLE |
| 580 | struct es_format_t |
| 581 | { |
| 582 | enum es_format_category_e i_cat; /**< ES category */ |
| 583 | vlc_fourcc_t i_codec; /**< FOURCC value as used in vlc */ |
| 584 | vlc_fourcc_t i_original_fourcc; /**< original FOURCC from the container */ |
| 585 | |
| 586 | int i_id; /**< es identifier, where means |
| 587 | -1: let the core mark the right id |
| 588 | >=0: valid id */ |
| 589 | int i_group; /**< group identifier, where means: |
| 590 | -1 : standalone |
| 591 | >= 0 then a "group" (program) is created |
| 592 | for each value */ |
| 593 | int i_priority; /**< priority, where means: |
| 594 | -2 : mean not selectable by the users |
| 595 | -1 : mean not selected by default even |
| 596 | when no other stream |
| 597 | >=0: priority */ |
| 598 | |
| 599 | char *psz_language; /**< human-readable language name */ |
| 600 | char *psz_description; /**< human-readable description of language */ |
| 601 | unsigned ; /**< length in bytes of extra language data pointer */ |
| 602 | extra_languages_t *; /**< extra language data needed by some decoders */ |
| 603 | |
| 604 | union { |
| 605 | struct { |
| 606 | audio_format_t audio; /**< description of audio format */ |
| 607 | audio_replay_gain_t audio_replay_gain; /*< audio replay gain information */ |
| 608 | }; |
| 609 | video_format_t video; /**< description of video format */ |
| 610 | subs_format_t subs; /**< description of subtitle format */ |
| 611 | }; |
| 612 | |
| 613 | unsigned int i_bitrate; /**< bitrate of this ES */ |
| 614 | int i_profile; /**< codec specific information (like real audio flavor, mpeg audio layer, h264 profile ...) */ |
| 615 | int i_level; /**< codec specific information: indicates maximum restrictions on the stream (resolution, bitrate, codec features ...) */ |
| 616 | |
| 617 | bool b_packetized; /**< whether the data is packetized (ie. not truncated) */ |
| 618 | int ; /**< length in bytes of extra data pointer */ |
| 619 | void *; /**< extra data needed by some decoders or muxers */ |
| 620 | |
| 621 | }; |
| 622 | |
| 623 | /** |
| 624 | * This function will fill all RGB shift from RGB masks. |
| 625 | */ |
| 626 | VLC_API void video_format_FixRgb( video_format_t * ); |
| 627 | |
| 628 | /** |
| 629 | * This function will initialize a es_format_t structure. |
| 630 | */ |
| 631 | VLC_API void es_format_Init( es_format_t *, int i_cat, vlc_fourcc_t i_codec ); |
| 632 | |
| 633 | /** |
| 634 | * This function will initialize a es_format_t structure from a video_format_t. |
| 635 | */ |
| 636 | VLC_API void es_format_InitFromVideo( es_format_t *, const video_format_t * ); |
| 637 | |
| 638 | /** |
| 639 | * This functions will copy a es_format_t. |
| 640 | */ |
| 641 | VLC_API int es_format_Copy( es_format_t *p_dst, const es_format_t *p_src ); |
| 642 | |
| 643 | /** |
| 644 | * This function will clean up a es_format_t and release all associated |
| 645 | * resources. |
| 646 | * You can call it multiple times on the same structure. |
| 647 | */ |
| 648 | VLC_API void es_format_Clean( es_format_t *fmt ); |
| 649 | |
| 650 | /** |
| 651 | * This function will check if the first ES format is similar |
| 652 | * to the second one. |
| 653 | * |
| 654 | * All descriptive fields are ignored. |
| 655 | */ |
| 656 | VLC_API bool es_format_IsSimilar( const es_format_t *, const es_format_t * ); |
| 657 | |
| 658 | /** |
| 659 | * Changes ES format to another category |
| 660 | * Format must have been properly initialized |
| 661 | */ |
| 662 | static inline void es_format_Change( es_format_t *fmt, int i_cat, vlc_fourcc_t i_codec ) |
| 663 | { |
| 664 | es_format_Clean( fmt ); |
| 665 | es_format_Init( fmt, i_cat, i_codec ); |
| 666 | } |
| 667 | |
| 668 | #endif |
| 669 | |