Libav
matroska.c
Go to the documentation of this file.
1 /*
2  * Matroska common data
3  * Copyright (c) 2003-2004 The FFmpeg project
4  *
5  * This file is part of Libav.
6  *
7  * Libav is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * Libav is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with Libav; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 #include "libavutil/stereo3d.h"
23 
24 #include "matroska.h"
25 
27  {"A_AAC" , AV_CODEC_ID_AAC},
28  {"A_AC3" , AV_CODEC_ID_AC3},
29  {"A_ALAC" , AV_CODEC_ID_ALAC},
30  {"A_DTS" , AV_CODEC_ID_DTS},
31  {"A_EAC3" , AV_CODEC_ID_EAC3},
32  {"A_FLAC" , AV_CODEC_ID_FLAC},
33  {"A_MLP" , AV_CODEC_ID_MLP},
34  {"A_MPEG/L2" , AV_CODEC_ID_MP2},
35  {"A_MPEG/L1" , AV_CODEC_ID_MP2},
36  {"A_MPEG/L3" , AV_CODEC_ID_MP3},
37  {"A_OPUS" , AV_CODEC_ID_OPUS},
38  {"A_PCM/FLOAT/IEEE" , AV_CODEC_ID_PCM_F32LE},
39  {"A_PCM/FLOAT/IEEE" , AV_CODEC_ID_PCM_F64LE},
40  {"A_PCM/INT/BIG" , AV_CODEC_ID_PCM_S16BE},
41  {"A_PCM/INT/BIG" , AV_CODEC_ID_PCM_S24BE},
42  {"A_PCM/INT/BIG" , AV_CODEC_ID_PCM_S32BE},
43  {"A_PCM/INT/LIT" , AV_CODEC_ID_PCM_S16LE},
44  {"A_PCM/INT/LIT" , AV_CODEC_ID_PCM_S24LE},
45  {"A_PCM/INT/LIT" , AV_CODEC_ID_PCM_S32LE},
46  {"A_PCM/INT/LIT" , AV_CODEC_ID_PCM_U8},
47  {"A_QUICKTIME/QDM2" , AV_CODEC_ID_QDM2},
48  {"A_REAL/14_4" , AV_CODEC_ID_RA_144},
49  {"A_REAL/28_8" , AV_CODEC_ID_RA_288},
50  {"A_REAL/ATRC" , AV_CODEC_ID_ATRAC3},
51  {"A_REAL/COOK" , AV_CODEC_ID_COOK},
52  {"A_REAL/SIPR" , AV_CODEC_ID_SIPR},
53  {"A_TRUEHD" , AV_CODEC_ID_TRUEHD},
54  {"A_TTA1" , AV_CODEC_ID_TTA},
55  {"A_VORBIS" , AV_CODEC_ID_VORBIS},
56  {"A_WAVPACK4" , AV_CODEC_ID_WAVPACK},
57 
58  {"S_TEXT/UTF8" , AV_CODEC_ID_SRT},
59  {"S_TEXT/UTF8" , AV_CODEC_ID_TEXT},
60  {"S_TEXT/ASCII" , AV_CODEC_ID_TEXT},
61  {"S_TEXT/ASS" , AV_CODEC_ID_SSA},
62  {"S_TEXT/SSA" , AV_CODEC_ID_SSA},
63  {"S_ASS" , AV_CODEC_ID_SSA},
64  {"S_SSA" , AV_CODEC_ID_SSA},
65  {"S_VOBSUB" , AV_CODEC_ID_DVD_SUBTITLE},
66  {"S_DVBSUB" , AV_CODEC_ID_DVB_SUBTITLE},
67  {"S_HDMV/PGS" , AV_CODEC_ID_HDMV_PGS_SUBTITLE},
68 
69  {"V_AV1" , AV_CODEC_ID_AV1},
70  {"V_DIRAC" , AV_CODEC_ID_DIRAC},
71  {"V_MJPEG" , AV_CODEC_ID_MJPEG},
72  {"V_MPEG1" , AV_CODEC_ID_MPEG1VIDEO},
73  {"V_MPEG2" , AV_CODEC_ID_MPEG2VIDEO},
74  {"V_MPEG4/ISO/ASP" , AV_CODEC_ID_MPEG4},
75  {"V_MPEG4/ISO/AP" , AV_CODEC_ID_MPEG4},
76  {"V_MPEG4/ISO/SP" , AV_CODEC_ID_MPEG4},
77  {"V_MPEG4/ISO/AVC" , AV_CODEC_ID_H264},
78  {"V_MPEGH/ISO/HEVC" , AV_CODEC_ID_HEVC},
79  {"V_MPEG4/MS/V3" , AV_CODEC_ID_MSMPEG4V3},
80  {"V_PRORES" , AV_CODEC_ID_PRORES},
81  {"V_REAL/RV10" , AV_CODEC_ID_RV10},
82  {"V_REAL/RV20" , AV_CODEC_ID_RV20},
83  {"V_REAL/RV30" , AV_CODEC_ID_RV30},
84  {"V_REAL/RV40" , AV_CODEC_ID_RV40},
85  {"V_THEORA" , AV_CODEC_ID_THEORA},
86  {"V_UNCOMPRESSED" , AV_CODEC_ID_RAWVIDEO},
87  {"V_VP8" , AV_CODEC_ID_VP8},
88  {"V_VP9" , AV_CODEC_ID_VP9},
89 
90  {"" , AV_CODEC_ID_NONE}
91 };
92 
94  {"image/gif" , AV_CODEC_ID_GIF},
95  {"image/jpeg" , AV_CODEC_ID_MJPEG},
96  {"image/png" , AV_CODEC_ID_PNG},
97  {"image/tiff" , AV_CODEC_ID_TIFF},
98 
99  {"" , AV_CODEC_ID_NONE}
100 };
101 
103  {"text/plain" , AV_CODEC_ID_TEXT},
104  {"application/x-truetype-font", AV_CODEC_ID_TTF},
105  {"application/x-font" , AV_CODEC_ID_TTF},
106 
107  {"" , AV_CODEC_ID_NONE}
108 };
109 
111  { "LEAD_PERFORMER", "performer" },
112  { "PART_NUMBER" , "track" },
113  { 0 }
114 };
115 
117 {
118  AVPacketSideData *sd, *tmp;
119  AVStereo3D *stereo;
120 
121  stereo = av_stereo3d_alloc();
122  if (!stereo)
123  return AVERROR(ENOMEM);
124 
125  tmp = av_realloc_array(st->side_data, st->nb_side_data + 1, sizeof(*tmp));
126  if (!tmp) {
127  av_freep(&stereo);
128  return AVERROR(ENOMEM);
129  }
130  st->side_data = tmp;
131  st->nb_side_data++;
132 
133  sd = &st->side_data[st->nb_side_data - 1];
135  sd->data = (uint8_t *)stereo;
136  sd->size = sizeof(*stereo);
137 
138  // note: the missing breaks are intentional
139  switch (stereo_mode) {
141  stereo->type = AV_STEREO3D_2D;
142  break;
144  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
146  stereo->type = AV_STEREO3D_SIDEBYSIDE;
147  break;
149  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
151  stereo->type = AV_STEREO3D_TOPBOTTOM;
152  break;
154  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
156  stereo->type = AV_STEREO3D_CHECKERBOARD;
157  break;
159  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
161  stereo->type = AV_STEREO3D_LINES;
162  break;
164  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
166  stereo->type = AV_STEREO3D_COLUMNS;
167  break;
169  stereo->flags |= AV_STEREO3D_FLAG_INVERT;
172  break;
173  }
174 
175  return 0;
176 }
Views are packed per line, as if interlaced.
Definition: stereo3d.h:97
Views are alternated temporally.
Definition: stereo3d.h:66
This side data should be associated with a video stream and contains Stereoscopic 3D information in f...
Definition: avcodec.h:1260
AVPacketSideData * side_data
An array of side data that applies to the whole stream (i.e.
Definition: avformat.h:808
MatroskaVideoStereoModeType
Definition: matroska.h:240
void av_freep(void *arg)
Free a memory block which has been allocated with av_malloc(z)() or av_realloc() and set the pointer ...
Definition: mem.c:202
uint8_t
Stereo 3D type: this structure describes how two videos are packed within a single video surface...
Definition: stereo3d.h:123
int ff_mkv_stereo3d_conv(AVStream *st, MatroskaVideoStereoModeType stereo_mode)
Definition: matroska.c:116
int nb_side_data
The number of elements in the AVStream.side_data array.
Definition: avformat.h:812
uint8_t * data
Definition: avcodec.h:1290
int flags
Additional information about the frame packing.
Definition: stereo3d.h:132
#define AVERROR(e)
Definition: error.h:43
preferred ID for decoding MPEG audio layer 1, 2 or 3
Definition: avcodec.h:479
enum AVPacketSideDataType type
Definition: avcodec.h:1292
Video is not stereoscopic (and metadata has to be there).
Definition: stereo3d.h:35
const CodecMime ff_mkv_mime_tags[]
Definition: matroska.c:102
#define AV_STEREO3D_FLAG_INVERT
Inverted views, Right/Bottom represents the left view.
Definition: stereo3d.h:114
preferred ID for MPEG-1/2 video decoding
Definition: avcodec.h:198
Stream structure.
Definition: avformat.h:705
enum AVStereo3DType type
How views are packed within the video.
Definition: stereo3d.h:127
Views are on top of each other.
Definition: stereo3d.h:55
const AVMetadataConv ff_mkv_metadata_conv[]
Definition: matroska.c:110
Views are next to each other.
Definition: stereo3d.h:45
raw UTF-8 text
Definition: avcodec.h:553
void * av_realloc_array(void *ptr, size_t nmemb, size_t size)
Definition: mem.c:161
static uint8_t tmp[8]
Definition: des.c:38
Views are packed in a checkerboard-like structure per pixel.
Definition: stereo3d.h:76
Views are packed per column.
Definition: stereo3d.h:107
const CodecMime ff_mkv_image_mime_tags[]
Definition: matroska.c:93
AVStereo3D * av_stereo3d_alloc(void)
Allocate an AVStereo3D structure and set its fields to default values.
Definition: stereo3d.c:28
const CodecTags ff_mkv_codec_tags[]
Definition: matroska.c:26