Mercurial > libavcodec.hg
annotate avcodec.h @ 11835:758c052eb8a9 libavcodec
aac: Move an initialization macro used only by the decoder out of the header.
author | alexc |
---|---|
date | Sat, 05 Jun 2010 15:31:57 +0000 |
parents | e522dbf60abd |
children | 9a18fa62aa52 |
rev | line source |
---|---|
3699
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
1 /* |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
2 * copyright (c) 2001 Fabrice Bellard |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
3 * |
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
4 * This file is part of FFmpeg. |
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
5 * |
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
6 * FFmpeg is free software; you can redistribute it and/or |
3699
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
7 * modify it under the terms of the GNU Lesser General Public |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
8 * License as published by the Free Software Foundation; either |
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
9 * version 2.1 of the License, or (at your option) any later version. |
3699
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
10 * |
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
11 * FFmpeg is distributed in the hope that it will be useful, |
3699
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
14 * Lesser General Public License for more details. |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
15 * |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
16 * You should have received a copy of the GNU Lesser General Public |
3947
c8c591fe26f8
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
3930
diff
changeset
|
17 * License along with FFmpeg; if not, write to the Free Software |
5215 | 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
3699
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
19 */ |
c537a97eec66
Add official LGPL license headers to the files that were missing them.
diego
parents:
3695
diff
changeset
|
20 |
7760 | 21 #ifndef AVCODEC_AVCODEC_H |
22 #define AVCODEC_AVCODEC_H | |
92 | 23 |
1048 | 24 /** |
11644
7dd2a45249a9
Remove explicit filename from Doxygen @file commands.
diego
parents:
11567
diff
changeset
|
25 * @file |
4794 | 26 * external API header |
1048 | 27 */ |
28 | |
8667 | 29 #include <errno.h> |
6395 | 30 #include "libavutil/avutil.h" |
0 | 31 |
7823
4525dcd81357
Bump Major version, this commit is almost just renaming bits_per_sample to
michael
parents:
7786
diff
changeset
|
32 #define LIBAVCODEC_VERSION_MAJOR 52 |
11821 | 33 #define LIBAVCODEC_VERSION_MINOR 74 |
11832
e522dbf60abd
Move eval.c and eval.h from libavcodec to libavutil, and make the eval
stefano
parents:
11823
diff
changeset
|
34 #define LIBAVCODEC_VERSION_MICRO 1 |
6378 | 35 |
6417 | 36 #define LIBAVCODEC_VERSION_INT AV_VERSION_INT(LIBAVCODEC_VERSION_MAJOR, \ |
37 LIBAVCODEC_VERSION_MINOR, \ | |
38 LIBAVCODEC_VERSION_MICRO) | |
39 #define LIBAVCODEC_VERSION AV_VERSION(LIBAVCODEC_VERSION_MAJOR, \ | |
40 LIBAVCODEC_VERSION_MINOR, \ | |
41 LIBAVCODEC_VERSION_MICRO) | |
2979 | 42 #define LIBAVCODEC_BUILD LIBAVCODEC_VERSION_INT |
2814 | 43 |
2979 | 44 #define LIBAVCODEC_IDENT "Lavc" AV_STRINGIFY(LIBAVCODEC_VERSION) |
1118 | 45 |
4274 | 46 #define AV_NOPTS_VALUE INT64_C(0x8000000000000000) |
2979 | 47 #define AV_TIME_BASE 1000000 |
48 #define AV_TIME_BASE_Q (AVRational){1, AV_TIME_BASE} | |
1831
cd2d7fcfab7a
use AVFrame.pts=AV_NOPTS_VALUE instead of AVFrame.pts=0
michael
parents:
1812
diff
changeset
|
49 |
4743 | 50 /** |
5139 | 51 * Identifies the syntax and semantics of the bitstream. |
52 * The principle is roughly: | |
53 * Two decoders with the same ID can decode the same streams. | |
54 * Two encoders with the same ID can encode compatible streams. | |
55 * There may be slight deviations from the principle due to implementation | |
56 * details. | |
4743 | 57 * |
4794 | 58 * If you add a codec ID to this list, add it so that |
59 * 1. no value of a existing codec ID changes (that would break ABI), | |
60 * 2. it is as close as possible to similar codecs. | |
4743 | 61 */ |
0 | 62 enum CodecID { |
2967 | 63 CODEC_ID_NONE, |
6587 | 64 |
65 /* video codecs */ | |
0 | 66 CODEC_ID_MPEG1VIDEO, |
6037 | 67 CODEC_ID_MPEG2VIDEO, ///< preferred ID for MPEG-1/2 video decoding |
1382 | 68 CODEC_ID_MPEG2VIDEO_XVMC, |
2044
b6f2add2511e
h261 decoder by (Maarten Daniels <maarten.daniels at student dot luc dot ac dot be>)
michael
parents:
2030
diff
changeset
|
69 CODEC_ID_H261, |
0 | 70 CODEC_ID_H263, |
71 CODEC_ID_RV10, | |
1639 | 72 CODEC_ID_RV20, |
0 | 73 CODEC_ID_MJPEG, |
881 | 74 CODEC_ID_MJPEGB, |
1315
6696d3bf4ff2
lossless mjpeg encoding (planar yuv & RGB) and somerelated bugfixes
michaelni
parents:
1306
diff
changeset
|
75 CODEC_ID_LJPEG, |
1519 | 76 CODEC_ID_SP5X, |
2970
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
77 CODEC_ID_JPEGLS, |
67 | 78 CODEC_ID_MPEG4, |
0 | 79 CODEC_ID_RAWVIDEO, |
307 | 80 CODEC_ID_MSMPEG4V1, |
81 CODEC_ID_MSMPEG4V2, | |
82 CODEC_ID_MSMPEG4V3, | |
311 | 83 CODEC_ID_WMV1, |
485 | 84 CODEC_ID_WMV2, |
0 | 85 CODEC_ID_H263P, |
86 CODEC_ID_H263I, | |
1353
cfc80b3a4ada
flash video (flv) support patch by (Garrick Meeker <gmeeker at theoryllc dot com>)
michaelni
parents:
1347
diff
changeset
|
87 CODEC_ID_FLV1, |
521 | 88 CODEC_ID_SVQ1, |
1234 | 89 CODEC_ID_SVQ3, |
724 | 90 CODEC_ID_DVVIDEO, |
866 | 91 CODEC_ID_HUFFYUV, |
1054
f874e2122d45
Creative YUV (CYUV) decoder by (Mike Melanson <melanson at pcisys dot net>)
michaelni
parents:
1053
diff
changeset
|
92 CODEC_ID_CYUV, |
1168 | 93 CODEC_ID_H264, |
1190 | 94 CODEC_ID_INDEO3, |
1224 | 95 CODEC_ID_VP3, |
1516
0f0e9dfa6723
theora decoding support (only keyframes for now, because by theora the frame isn't flipped so the motion vectors are getting screwed up)
alex
parents:
1510
diff
changeset
|
96 CODEC_ID_THEORA, |
1273 | 97 CODEC_ID_ASV1, |
1433 | 98 CODEC_ID_ASV2, |
1300
e18667d1e94d
FFV1 codec (our very simple lossless intra only codec, compresses much better then huffyuv)
michaelni
parents:
1299
diff
changeset
|
99 CODEC_ID_FFV1, |
1286 | 100 CODEC_ID_4XM, |
1374 | 101 CODEC_ID_VCR1, |
1385 | 102 CODEC_ID_CLJR, |
1410
524c904a66b8
PSX MDEC decoder, based upon some code from Sebastian Jedruszkiewicz <elf at frogger dot rules dot pl>
michaelni
parents:
1404
diff
changeset
|
103 CODEC_ID_MDEC, |
1439
a4d00b1f0271
initial commit for Id RoQ and Interplay MVE multimedia subsystems
tmmm
parents:
1433
diff
changeset
|
104 CODEC_ID_ROQ, |
a4d00b1f0271
initial commit for Id RoQ and Interplay MVE multimedia subsystems
tmmm
parents:
1433
diff
changeset
|
105 CODEC_ID_INTERPLAY_VIDEO, |
1443
47f4c8a5a7fc
New fringe codecs: WC3/Xan video, Xan DPCM, DK3 & DK4 ADPCM
tmmm
parents:
1442
diff
changeset
|
106 CODEC_ID_XAN_WC3, |
47f4c8a5a7fc
New fringe codecs: WC3/Xan video, Xan DPCM, DK3 & DK4 ADPCM
tmmm
parents:
1442
diff
changeset
|
107 CODEC_ID_XAN_WC4, |
1491
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
108 CODEC_ID_RPZA, |
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
109 CODEC_ID_CINEPAK, |
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
110 CODEC_ID_WS_VQA, |
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
111 CODEC_ID_MSRLE, |
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
112 CODEC_ID_MSVIDEO1, |
1498 | 113 CODEC_ID_IDCIN, |
1608 | 114 CODEC_ID_8BPS, |
1610 | 115 CODEC_ID_SMC, |
1624 | 116 CODEC_ID_FLIC, |
1650
bdade3baabfc
initial support for Duck TrueMotion v1 (think of it as On2 VP1); only
melanson
parents:
1644
diff
changeset
|
117 CODEC_ID_TRUEMOTION1, |
1717
6a7e68899d8a
first pass at Sierra VMD A/V decoders; video looks great, audio is not
melanson
parents:
1708
diff
changeset
|
118 CODEC_ID_VMDVIDEO, |
1741 | 119 CODEC_ID_MSZH, |
120 CODEC_ID_ZLIB, | |
1783
66ae3c109d90
initial commit for Quicktime Animation (RLE) video decoder; bit depths
melanson
parents:
1782
diff
changeset
|
121 CODEC_ID_QTRLE, |
2138 | 122 CODEC_ID_SNOW, |
2170
51da590b31a3
TechSmith Camtasia (TSCC) video decoder, courtesy of Konstantin Shishkov
melanson
parents:
2167
diff
changeset
|
123 CODEC_ID_TSCC, |
2234
dff53892ff8a
IBM Ultimotion video decoder, courtesy of Konstantin Shishkov
melanson
parents:
2201
diff
changeset
|
124 CODEC_ID_ULTI, |
2275
c443a6af19a7
support for Sierra Online audio files and Apple QuickDraw codec,
melanson
parents:
2272
diff
changeset
|
125 CODEC_ID_QDRAW, |
2325
1180a04d64c5
Miro VideoXL (VIXL) decoder, courtesy of Konstantin Shishkov
melanson
parents:
2322
diff
changeset
|
126 CODEC_ID_VIXL, |
2355
69fcdad5f7d5
native QPEG video decoder, courtesy of Konstantin Shishkov
melanson
parents:
2353
diff
changeset
|
127 CODEC_ID_QPEG, |
11479
59c11c1f3991
CODEC_ID_XVID is not used anywhere, remove it at next major bump
aurel
parents:
11478
diff
changeset
|
128 #if LIBAVCODEC_VERSION_MAJOR < 53 |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
129 CODEC_ID_XVID, |
11479
59c11c1f3991
CODEC_ID_XVID is not used anywhere, remove it at next major bump
aurel
parents:
11478
diff
changeset
|
130 #endif |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
131 CODEC_ID_PNG, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
132 CODEC_ID_PPM, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
133 CODEC_ID_PBM, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
134 CODEC_ID_PGM, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
135 CODEC_ID_PGMYUV, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
136 CODEC_ID_PAM, |
2373 | 137 CODEC_ID_FFVHUFF, |
2413 | 138 CODEC_ID_RV30, |
139 CODEC_ID_RV40, | |
3359 | 140 CODEC_ID_VC1, |
2445
96da66323faa
preliminary vc9 bitstream decoder, committing to make syncing and team-work on it easier
alex
parents:
2432
diff
changeset
|
141 CODEC_ID_WMV3, |
2530 | 142 CODEC_ID_LOCO, |
2577
7d9997a69158
Winnov WNV1 video decoder, courtesy of Konstantin Shishkov
melanson
parents:
2572
diff
changeset
|
143 CODEC_ID_WNV1, |
2588
b6b618986f80
Autodesk Animator Studio Codec (AASC) video decoder, courtesy of
melanson
parents:
2585
diff
changeset
|
144 CODEC_ID_AASC, |
2618
fc91ca5b9066
Indeo 2 decoder by (Kostya <> kostya.shishkov gmail com)
michael
parents:
2588
diff
changeset
|
145 CODEC_ID_INDEO2, |
2700
485571c9182f
Fraps FPS1 video decoder (v1 & v2), courtesy of Roine Gustafsson <roine
melanson
parents:
2697
diff
changeset
|
146 CODEC_ID_FRAPS, |
2906
e578b3572987
Duck TrueMotion 2 video decoder, courtesy of Konstantin Shishkov
melanson
parents:
2880
diff
changeset
|
147 CODEC_ID_TRUEMOTION2, |
2949 | 148 CODEC_ID_BMP, |
3030 | 149 CODEC_ID_CSCD, |
3119
09ae2e981d64
complete American Laser Games MM playback system, courtesy of Peter Ross
melanson
parents:
3118
diff
changeset
|
150 CODEC_ID_MMVIDEO, |
3120 | 151 CODEC_ID_ZMBV, |
3129
0ebbd476ba32
complete AVS playback system (from Creature Shock computer game),
melanson
parents:
3127
diff
changeset
|
152 CODEC_ID_AVS, |
3209 | 153 CODEC_ID_SMACKVIDEO, |
3224
28aaf0a0135e
NuppelVideo/MythTVVideo support, including rtjpeg decoder
reimar
parents:
3209
diff
changeset
|
154 CODEC_ID_NUV, |
3253
226ffbb6fd02
KMVC (used in Worms games) decoder. Works fine with samples from MPHQ
kostya
parents:
3251
diff
changeset
|
155 CODEC_ID_KMVC, |
3329 | 156 CODEC_ID_FLASHSV, |
3392
11c9d7dad1c8
CODEC_ID_CAVS (part of the cavs patch by Stefan Gehrer stefan.gehrer gmx de)
michael
parents:
3385
diff
changeset
|
157 CODEC_ID_CAVS, |
3618 | 158 CODEC_ID_JPEG2000, |
3677 | 159 CODEC_ID_VMNC, |
3695 | 160 CODEC_ID_VP5, |
161 CODEC_ID_VP6, | |
162 CODEC_ID_VP6F, | |
3986 | 163 CODEC_ID_TARGA, |
3997
8ed26e786210
support for Delphine Software .cin files demuxing / audio and video decoding, by Gregory Montoir %cyx A users P sourceforge P net%
bcoudurier
parents:
3986
diff
changeset
|
164 CODEC_ID_DSICINVIDEO, |
4006
986d6651a452
support for Tiertex .seq files demuxing/video decoding, by Gregory Montoir %cyx A users P sourceforge P net%
bcoudurier
parents:
3998
diff
changeset
|
165 CODEC_ID_TIERTEXSEQVIDEO, |
4013 | 166 CODEC_ID_TIFF, |
4054 | 167 CODEC_ID_GIF, |
4278 | 168 CODEC_ID_FFH264, |
4671 | 169 CODEC_ID_DXA, |
4687 | 170 CODEC_ID_DNXHD, |
4761
4effe3bde31b
support for the THP game format by Marco Gerards, mgerards xs4all nl
diego
parents:
4743
diff
changeset
|
171 CODEC_ID_THP, |
4790 | 172 CODEC_ID_SGI, |
4797 | 173 CODEC_ID_C93, |
4803 | 174 CODEC_ID_BETHSOFTVID, |
4884 | 175 CODEC_ID_PTX, |
4934 | 176 CODEC_ID_TXD, |
5714
314be1cfdcb0
add a new vp6a codec (add alpha plan support to vp6)
aurel
parents:
5687
diff
changeset
|
177 CODEC_ID_VP6A, |
5736 | 178 CODEC_ID_AMV, |
5847 | 179 CODEC_ID_VB, |
6073 | 180 CODEC_ID_PCX, |
6084 | 181 CODEC_ID_SUNRAST, |
6422 | 182 CODEC_ID_INDEO4, |
183 CODEC_ID_INDEO5, | |
6508 | 184 CODEC_ID_MIMIC, |
6523 | 185 CODEC_ID_RL2, |
6547 | 186 CODEC_ID_8SVX_EXP, |
187 CODEC_ID_8SVX_FIB, | |
6549 | 188 CODEC_ID_ESCAPE124, |
6573 | 189 CODEC_ID_DIRAC, |
6593 | 190 CODEC_ID_BFI, |
7222 | 191 CODEC_ID_CMV, |
7231 | 192 CODEC_ID_MOTIONPIXELS, |
7510 | 193 CODEC_ID_TGV, |
8119 | 194 CODEC_ID_TGQ, |
8745 | 195 CODEC_ID_TQI, |
9227
98f102ead3c6
Add AURA 1 and 2 codec IDs and register their FOURCCs
kostya
parents:
9222
diff
changeset
|
196 CODEC_ID_AURA, |
98f102ead3c6
Add AURA 1 and 2 codec IDs and register their FOURCCs
kostya
parents:
9222
diff
changeset
|
197 CODEC_ID_AURA2, |
9535
4a4929da4ddc
Support reading packed YUV422 10bit samples from Sveriges Television AB (SVT)
michael
parents:
9502
diff
changeset
|
198 CODEC_ID_V210X, |
9616 | 199 CODEC_ID_TMV, |
9628
4b6766057548
V210 Uncompressed 4:2:2 10-bit encoder and decoder
bcoudurier
parents:
9626
diff
changeset
|
200 CODEC_ID_V210, |
9839 | 201 CODEC_ID_DPX, |
9848 | 202 CODEC_ID_MAD, |
10394 | 203 CODEC_ID_FRWU, |
10547
8a2d04d5deb9
Add codec id for Flash screen codec v2 and hook it up in FLV demuxer
daniel
parents:
10536
diff
changeset
|
204 CODEC_ID_FLASHSV2, |
10692 | 205 CODEC_ID_CDGRAPHICS, |
10693
0aec5a890b83
Add decoder for R210 (uncompressed 10-bit RGB) codec.
reimar
parents:
10692
diff
changeset
|
206 CODEC_ID_R210, |
10835 | 207 CODEC_ID_ANM, |
11055 | 208 CODEC_ID_BINKVIDEO, |
11074 | 209 CODEC_ID_IFF_ILBM, |
210 CODEC_ID_IFF_BYTERUN1, | |
11425 | 211 CODEC_ID_KGV1, |
11553 | 212 CODEC_ID_YOP, |
11744 | 213 CODEC_ID_VP8, |
92 | 214 |
4794 | 215 /* various PCM "codecs" */ |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
216 CODEC_ID_PCM_S16LE= 0x10000, |
92 | 217 CODEC_ID_PCM_S16BE, |
218 CODEC_ID_PCM_U16LE, | |
219 CODEC_ID_PCM_U16BE, | |
220 CODEC_ID_PCM_S8, | |
221 CODEC_ID_PCM_U8, | |
222 CODEC_ID_PCM_MULAW, | |
223 CODEC_ID_PCM_ALAW, | |
2852
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
224 CODEC_ID_PCM_S32LE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
225 CODEC_ID_PCM_S32BE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
226 CODEC_ID_PCM_U32LE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
227 CODEC_ID_PCM_U32BE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
228 CODEC_ID_PCM_S24LE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
229 CODEC_ID_PCM_S24BE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
230 CODEC_ID_PCM_U24LE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
231 CODEC_ID_PCM_U24BE, |
6f7428adc6ad
Support de-/encoding of 24 and 32 bit PCM (from and to internal 16 bit).
reimar
parents:
2843
diff
changeset
|
232 CODEC_ID_PCM_S24DAUD, |
5422 | 233 CODEC_ID_PCM_ZORK, |
5940
d63186919b60
add pcm_s16le_planar support for electronicarts files
aurel
parents:
5922
diff
changeset
|
234 CODEC_ID_PCM_S16LE_PLANAR, |
6821
1b9c458d6d60
LPCM 24 bits support, patch by Lars T«£uber, lars.taeuber gmx net
diego
parents:
6776
diff
changeset
|
235 CODEC_ID_PCM_DVD, |
7409
21770337ff2d
add CODEC_ID_PCM_F32BE (32-bit floating point PCM big endian decoder)
pross
parents:
7406
diff
changeset
|
236 CODEC_ID_PCM_F32BE, |
7613 | 237 CODEC_ID_PCM_F32LE, |
238 CODEC_ID_PCM_F64BE, | |
239 CODEC_ID_PCM_F64LE, | |
10099 | 240 CODEC_ID_PCM_BLURAY, |
573
b0f52172f4c5
beos/mov/adpcm patch by Fran«®ois Revol <revol at free dot fr>
michaelni
parents:
556
diff
changeset
|
241 |
4794 | 242 /* various ADPCM codecs */ |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
243 CODEC_ID_ADPCM_IMA_QT= 0x11000, |
573
b0f52172f4c5
beos/mov/adpcm patch by Fran«®ois Revol <revol at free dot fr>
michaelni
parents:
556
diff
changeset
|
244 CODEC_ID_ADPCM_IMA_WAV, |
1443
47f4c8a5a7fc
New fringe codecs: WC3/Xan video, Xan DPCM, DK3 & DK4 ADPCM
tmmm
parents:
1442
diff
changeset
|
245 CODEC_ID_ADPCM_IMA_DK3, |
47f4c8a5a7fc
New fringe codecs: WC3/Xan video, Xan DPCM, DK3 & DK4 ADPCM
tmmm
parents:
1442
diff
changeset
|
246 CODEC_ID_ADPCM_IMA_DK4, |
1491
222643544cf1
New demuxers: Sega FILM/CPK, Westwood VQA & AUD; new decoders: MS RLE &
tmmm
parents:
1490
diff
changeset
|
247 CODEC_ID_ADPCM_IMA_WS, |
1779 | 248 CODEC_ID_ADPCM_IMA_SMJPEG, |
573
b0f52172f4c5
beos/mov/adpcm patch by Fran«®ois Revol <revol at free dot fr>
michaelni
parents:
556
diff
changeset
|
249 CODEC_ID_ADPCM_MS, |
1286 | 250 CODEC_ID_ADPCM_4XM, |
1535 | 251 CODEC_ID_ADPCM_XA, |
252 CODEC_ID_ADPCM_ADX, | |
1779 | 253 CODEC_ID_ADPCM_EA, |
1791
5e5c3d4a1e82
* Initial implementation of the G.726 ADPCM audio codec.
romansh
parents:
1783
diff
changeset
|
254 CODEC_ID_ADPCM_G726, |
2296
2b75dff01118
Creative ADPCM decoder, format 0x200, courtesy of Konstantin Shishkov
melanson
parents:
2279
diff
changeset
|
255 CODEC_ID_ADPCM_CT, |
2516
9f17dd9b80c6
macromedia flavour adpcm decoding (used in flv and swf)
alex
parents:
2507
diff
changeset
|
256 CODEC_ID_ADPCM_SWF, |
2794
ed1ab1566353
Add Yamaha ADPCM encoding/decoding patch by (Vidar Madsen: vidarino, gmail com)
michael
parents:
2792
diff
changeset
|
257 CODEC_ID_ADPCM_YAMAHA, |
3127 | 258 CODEC_ID_ADPCM_SBPRO_4, |
259 CODEC_ID_ADPCM_SBPRO_3, | |
260 CODEC_ID_ADPCM_SBPRO_2, | |
4800 | 261 CODEC_ID_ADPCM_THP, |
5726 | 262 CODEC_ID_ADPCM_IMA_AMV, |
5851 | 263 CODEC_ID_ADPCM_EA_R1, |
264 CODEC_ID_ADPCM_EA_R3, | |
265 CODEC_ID_ADPCM_EA_R2, | |
5853 | 266 CODEC_ID_ADPCM_IMA_EA_SEAD, |
5854 | 267 CODEC_ID_ADPCM_IMA_EA_EACS, |
5870 | 268 CODEC_ID_ADPCM_EA_XAS, |
6596 | 269 CODEC_ID_ADPCM_EA_MAXIS_XA, |
8615 | 270 CODEC_ID_ADPCM_IMA_ISS, |
1258
802614404398
AMR-NB audio support patch by (<joca at rixmail dot se>)
michaelni
parents:
1245
diff
changeset
|
271 |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
272 /* AMR */ |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
273 CODEC_ID_AMR_NB= 0x12000, |
1486
f22010affdce
AMR-WB support by (Johannes Carlsson <joca at rixmail dot se>)
michaelni
parents:
1471
diff
changeset
|
274 CODEC_ID_AMR_WB, |
f22010affdce
AMR-WB support by (Johannes Carlsson <joca at rixmail dot se>)
michaelni
parents:
1471
diff
changeset
|
275 |
1304
e8543aab0cc9
RealAudio 1.0 (14_4) and 2.0 (28_8) native decoders. Author unknown, code from a mplayerhq (originally from public domain player for Amiga
nickols_k
parents:
1300
diff
changeset
|
276 /* RealAudio codecs*/ |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
277 CODEC_ID_RA_144= 0x13000, |
1304
e8543aab0cc9
RealAudio 1.0 (14_4) and 2.0 (28_8) native decoders. Author unknown, code from a mplayerhq (originally from public domain player for Amiga
nickols_k
parents:
1300
diff
changeset
|
278 CODEC_ID_RA_288, |
1439
a4d00b1f0271
initial commit for Id RoQ and Interplay MVE multimedia subsystems
tmmm
parents:
1433
diff
changeset
|
279 |
a4d00b1f0271
initial commit for Id RoQ and Interplay MVE multimedia subsystems
tmmm
parents:
1433
diff
changeset
|
280 /* various DPCM codecs */ |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
281 CODEC_ID_ROQ_DPCM= 0x14000, |
1439
a4d00b1f0271
initial commit for Id RoQ and Interplay MVE multimedia subsystems
tmmm
parents:
1433
diff
changeset
|
282 CODEC_ID_INTERPLAY_DPCM, |
1443
47f4c8a5a7fc
New fringe codecs: WC3/Xan video, Xan DPCM, DK3 & DK4 ADPCM
tmmm
parents:
1442
diff
changeset
|
283 CODEC_ID_XAN_DPCM, |
2275
c443a6af19a7
support for Sierra Online audio files and Apple QuickDraw codec,
melanson
parents:
2272
diff
changeset
|
284 CODEC_ID_SOL_DPCM, |
2967 | 285 |
6587 | 286 /* audio codecs */ |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
287 CODEC_ID_MP2= 0x15000, |
6037 | 288 CODEC_ID_MP3, ///< preferred ID for decoding MPEG audio layer 1, 2 or 3 |
2372
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
289 CODEC_ID_AAC, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
290 CODEC_ID_AC3, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
291 CODEC_ID_DTS, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
292 CODEC_ID_VORBIS, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
293 CODEC_ID_DVAUDIO, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
294 CODEC_ID_WMAV1, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
295 CODEC_ID_WMAV2, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
296 CODEC_ID_MACE3, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
297 CODEC_ID_MACE6, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
298 CODEC_ID_VMDAUDIO, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
299 CODEC_ID_SONIC, |
2d95a6cd757a
fix some codec_id values so that new ones can be added at the end of the subsets without breaking binary compatibility
michael
parents:
2370
diff
changeset
|
300 CODEC_ID_SONIC_LS, |
1812 | 301 CODEC_ID_FLAC, |
2432 | 302 CODEC_ID_MP3ADU, |
2507
0334caf0f0ce
Multichannel mp3 in mp4 support ISO/IEC 14496-3:2001/FPDAM 3 (MP3onMP4)
rtognimp
parents:
2501
diff
changeset
|
303 CODEC_ID_MP3ON4, |
2525
b47af698085e
shorten decoder by (Jeff Muizelaar <jrmuizel gmail com>)
michael
parents:
2522
diff
changeset
|
304 CODEC_ID_SHORTEN, |
2550 | 305 CODEC_ID_ALAC, |
2585 | 306 CODEC_ID_WESTWOOD_SND1, |
6037 | 307 CODEC_ID_GSM, ///< as in Berlin toast format |
2913 | 308 CODEC_ID_QDM2, |
2956
5f51b1e0bed6
Cook compatibe decoder, patch by Benjamin Larsson
rtognimp
parents:
2949
diff
changeset
|
309 CODEC_ID_COOK, |
3006
4007989367bc
TrueSpeech compatible audio decoder by Konstantin Shishkov
diego
parents:
2996
diff
changeset
|
310 CODEC_ID_TRUESPEECH, |
3118
01b58c3b8a91
tta decoder, tested with 44khz mono and stereo (for the latter use ffplay or change MAX_AUDIO_FRAME_SIZE)
alex
parents:
3100
diff
changeset
|
311 CODEC_ID_TTA, |
3209 | 312 CODEC_ID_SMACKAUDIO, |
3597 | 313 CODEC_ID_QCELP, |
3764 | 314 CODEC_ID_WAVPACK, |
3997
8ed26e786210
support for Delphine Software .cin files demuxing / audio and video decoding, by Gregory Montoir %cyx A users P sourceforge P net%
bcoudurier
parents:
3986
diff
changeset
|
315 CODEC_ID_DSICINAUDIO, |
4106 | 316 CODEC_ID_IMC, |
4328 | 317 CODEC_ID_MUSEPACK7, |
4489
27e74573b074
Revised patch for HD DVD .EVO demuxing by (Ian Caulfield <lowercase name seperated by . place at here gmail place a dot here com>)
michael
parents:
4477
diff
changeset
|
318 CODEC_ID_MLP, |
4794 | 319 CODEC_ID_GSM_MS, /* as found in WAV */ |
4856 | 320 CODEC_ID_ATRAC3, |
5406 | 321 CODEC_ID_VOXWARE, |
5673 | 322 CODEC_ID_APE, |
5823 | 323 CODEC_ID_NELLYMOSER, |
5879 | 324 CODEC_ID_MUSEPACK8, |
6337 | 325 CODEC_ID_SPEEX, |
6389
dc8990727103
Riff ids for wmapro and wmavoice, this adds support for stream copy of these codecs between asf,avi and wav containers.
banan
parents:
6382
diff
changeset
|
326 CODEC_ID_WMAVOICE, |
dc8990727103
Riff ids for wmapro and wmavoice, this adds support for stream copy of these codecs between asf,avi and wav containers.
banan
parents:
6382
diff
changeset
|
327 CODEC_ID_WMAPRO, |
6422 | 328 CODEC_ID_WMALOSSLESS, |
7029 | 329 CODEC_ID_ATRAC3P, |
7769 | 330 CODEC_ID_EAC3, |
7927
c6e9ff53dab4
Add support for Acelp.net fourcc and codecid, remuxing wav to avi should work
banan
parents:
7833
diff
changeset
|
331 CODEC_ID_SIPR, |
8585 | 332 CODEC_ID_MP1, |
9152 | 333 CODEC_ID_TWINVQ, |
9190 | 334 CODEC_ID_TRUEHD, |
9492
bdb94921332a
Introduce codec id for MPEG-4 ALS and associate it with corresponding
jai_menon
parents:
9415
diff
changeset
|
335 CODEC_ID_MP4ALS, |
10158 | 336 CODEC_ID_ATRAC1, |
11055 | 337 CODEC_ID_BINKAUDIO_RDFT, |
338 CODEC_ID_BINKAUDIO_DCT, | |
2967 | 339 |
2756 | 340 /* subtitle codecs */ |
2967 | 341 CODEC_ID_DVD_SUBTITLE= 0x17000, |
342 CODEC_ID_DVB_SUBTITLE, | |
6037 | 343 CODEC_ID_TEXT, ///< raw UTF-8 text |
5483 | 344 CODEC_ID_XSUB, |
6087
34abda474ff7
export raw SSA tracks with their own codec ID (patch by Evgeniy Stepanov)
aurel
parents:
6084
diff
changeset
|
345 CODEC_ID_SSA, |
6187
098f955eaec8
Add CODEC_ID_MOV_TEXT and use it instead of modifying the stream in the mov demuxer.
reimar
parents:
6184
diff
changeset
|
346 CODEC_ID_MOV_TEXT, |
10083 | 347 CODEC_ID_HDMV_PGS_SUBTITLE, |
10480 | 348 CODEC_ID_DVB_TELETEXT, |
2967 | 349 |
6486 | 350 /* other specific kind of codecs (generally used for attachments) */ |
6184 | 351 CODEC_ID_TTF= 0x18000, |
352 | |
7251 | 353 CODEC_ID_PROBE= 0x19000, ///< codec_id is not known (like CODEC_ID_NONE) but lavf should attempt to identify it |
354 | |
6037 | 355 CODEC_ID_MPEG2TS= 0x20000, /**< _FAKE_ codec to indicate a raw MPEG-2 TS |
4794 | 356 * stream (only used by libavformat) */ |
0 | 357 }; |
1447
7c73537bc994
changed my mind about CODEC_ID_MPEGVIDEO - CODEC_ID_MP3LAME is absolete
bellard
parents:
1443
diff
changeset
|
358 |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
359 #if LIBAVCODEC_VERSION_MAJOR < 53 |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
360 #define CodecType AVMediaType |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
361 |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
362 #define CODEC_TYPE_UNKNOWN AVMEDIA_TYPE_UNKNOWN |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
363 #define CODEC_TYPE_VIDEO AVMEDIA_TYPE_VIDEO |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
364 #define CODEC_TYPE_AUDIO AVMEDIA_TYPE_AUDIO |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
365 #define CODEC_TYPE_DATA AVMEDIA_TYPE_DATA |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
366 #define CODEC_TYPE_SUBTITLE AVMEDIA_TYPE_SUBTITLE |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
367 #define CODEC_TYPE_ATTACHMENT AVMEDIA_TYPE_ATTACHMENT |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
368 #define CODEC_TYPE_NB AVMEDIA_TYPE_NB |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
369 #endif |
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
370 |
6037 | 371 /** |
372 * all in native-endian format | |
373 */ | |
92 | 374 enum SampleFormat { |
3251 | 375 SAMPLE_FMT_NONE = -1, |
3136
ddf6d81a6369
added none/8bit/24bit audio formats and defaulting to s16 for now (once the system works like pix_fmt, the defaulting should be changed to SAMPLE_FMT_NONE)
alex
parents:
3132
diff
changeset
|
376 SAMPLE_FMT_U8, ///< unsigned 8 bits |
ddf6d81a6369
added none/8bit/24bit audio formats and defaulting to s16 for now (once the system works like pix_fmt, the defaulting should be changed to SAMPLE_FMT_NONE)
alex
parents:
3132
diff
changeset
|
377 SAMPLE_FMT_S16, ///< signed 16 bits |
2967 | 378 SAMPLE_FMT_S32, ///< signed 32 bits |
2479 | 379 SAMPLE_FMT_FLT, ///< float |
7612 | 380 SAMPLE_FMT_DBL, ///< double |
7410
4c68f77c49ee
add sample_fmts infrastructure: AVCodec->sample_fmts and SAMPLE_FMT_NB enum.
pross
parents:
7409
diff
changeset
|
381 SAMPLE_FMT_NB ///< Number of sample formats. DO NOT USE if dynamically linking to libavcodec |
92 | 382 }; |
383 | |
8098 | 384 /* Audio channel masks */ |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
385 #define CH_FRONT_LEFT 0x00000001 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
386 #define CH_FRONT_RIGHT 0x00000002 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
387 #define CH_FRONT_CENTER 0x00000004 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
388 #define CH_LOW_FREQUENCY 0x00000008 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
389 #define CH_BACK_LEFT 0x00000010 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
390 #define CH_BACK_RIGHT 0x00000020 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
391 #define CH_FRONT_LEFT_OF_CENTER 0x00000040 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
392 #define CH_FRONT_RIGHT_OF_CENTER 0x00000080 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
393 #define CH_BACK_CENTER 0x00000100 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
394 #define CH_SIDE_LEFT 0x00000200 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
395 #define CH_SIDE_RIGHT 0x00000400 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
396 #define CH_TOP_CENTER 0x00000800 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
397 #define CH_TOP_FRONT_LEFT 0x00001000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
398 #define CH_TOP_FRONT_CENTER 0x00002000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
399 #define CH_TOP_FRONT_RIGHT 0x00004000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
400 #define CH_TOP_BACK_LEFT 0x00008000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
401 #define CH_TOP_BACK_CENTER 0x00010000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
402 #define CH_TOP_BACK_RIGHT 0x00020000 |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
403 #define CH_STEREO_LEFT 0x20000000 ///< Stereo downmix. |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
404 #define CH_STEREO_RIGHT 0x40000000 ///< See CH_STEREO_LEFT. |
8098 | 405 |
10515
0655a0dd3c74
Add CH_LAYOUT_NATIVE channel mask value to allow user to request native codec
jbr
parents:
10480
diff
changeset
|
406 /** Channel mask value used for AVCodecContext.request_channel_layout |
0655a0dd3c74
Add CH_LAYOUT_NATIVE channel mask value to allow user to request native codec
jbr
parents:
10480
diff
changeset
|
407 to indicate that the user requests the channel order of the decoder output |
0655a0dd3c74
Add CH_LAYOUT_NATIVE channel mask value to allow user to request native codec
jbr
parents:
10480
diff
changeset
|
408 to be the native codec channel order. */ |
0655a0dd3c74
Add CH_LAYOUT_NATIVE channel mask value to allow user to request native codec
jbr
parents:
10480
diff
changeset
|
409 #define CH_LAYOUT_NATIVE 0x8000000000000000LL |
0655a0dd3c74
Add CH_LAYOUT_NATIVE channel mask value to allow user to request native codec
jbr
parents:
10480
diff
changeset
|
410 |
8098 | 411 /* Audio channel convenience macros */ |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
412 #define CH_LAYOUT_MONO (CH_FRONT_CENTER) |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
413 #define CH_LAYOUT_STEREO (CH_FRONT_LEFT|CH_FRONT_RIGHT) |
9502 | 414 #define CH_LAYOUT_2_1 (CH_LAYOUT_STEREO|CH_BACK_CENTER) |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
415 #define CH_LAYOUT_SURROUND (CH_LAYOUT_STEREO|CH_FRONT_CENTER) |
9502 | 416 #define CH_LAYOUT_4POINT0 (CH_LAYOUT_SURROUND|CH_BACK_CENTER) |
417 #define CH_LAYOUT_2_2 (CH_LAYOUT_STEREO|CH_SIDE_LEFT|CH_SIDE_RIGHT) | |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
418 #define CH_LAYOUT_QUAD (CH_LAYOUT_STEREO|CH_BACK_LEFT|CH_BACK_RIGHT) |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
419 #define CH_LAYOUT_5POINT0 (CH_LAYOUT_SURROUND|CH_SIDE_LEFT|CH_SIDE_RIGHT) |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
420 #define CH_LAYOUT_5POINT1 (CH_LAYOUT_5POINT0|CH_LOW_FREQUENCY) |
9351
4b801f9ae493
Add convenience macros for 5.0/5.1 back speaker configurations.
jbr
parents:
9342
diff
changeset
|
421 #define CH_LAYOUT_5POINT0_BACK (CH_LAYOUT_SURROUND|CH_BACK_LEFT|CH_BACK_RIGHT) |
4b801f9ae493
Add convenience macros for 5.0/5.1 back speaker configurations.
jbr
parents:
9342
diff
changeset
|
422 #define CH_LAYOUT_5POINT1_BACK (CH_LAYOUT_5POINT0_BACK|CH_LOW_FREQUENCY) |
10099 | 423 #define CH_LAYOUT_7POINT0 (CH_LAYOUT_5POINT0|CH_BACK_LEFT|CH_BACK_RIGHT) |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
424 #define CH_LAYOUT_7POINT1 (CH_LAYOUT_5POINT1|CH_BACK_LEFT|CH_BACK_RIGHT) |
9351
4b801f9ae493
Add convenience macros for 5.0/5.1 back speaker configurations.
jbr
parents:
9342
diff
changeset
|
425 #define CH_LAYOUT_7POINT1_WIDE (CH_LAYOUT_5POINT1_BACK|\ |
8102
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
426 CH_FRONT_LEFT_OF_CENTER|CH_FRONT_RIGHT_OF_CENTER) |
04295cbc0e9b
Change multichannel API define prefix from "CHANNEL_" to "CH_".
andoma
parents:
8098
diff
changeset
|
427 #define CH_LAYOUT_STEREO_DOWNMIX (CH_STEREO_LEFT|CH_STEREO_RIGHT) |
8098 | 428 |
0 | 429 /* in bytes */ |
3123
fc43390719fc
increase audio buffer to 1second of 48khz float audio
alex
parents:
3120
diff
changeset
|
430 #define AVCODEC_MAX_AUDIO_FRAME_SIZE 192000 // 1 second of 48khz 32bit audio |
0 | 431 |
842
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
432 /** |
1289
57172377849a
fix mpeg1/2 decoding if there are no 0 bytes after the bitstream
michaelni
parents:
1286
diff
changeset
|
433 * Required number of additionally allocated bytes at the end of the input bitstream for decoding. |
11438
db5623d197a3
Revert r22288 "Increase FF_INPUT_BUFFER_PADDING_SIZE to 64."
alexc
parents:
11426
diff
changeset
|
434 * This is mainly needed because some optimized bitstream readers read |
db5623d197a3
Revert r22288 "Increase FF_INPUT_BUFFER_PADDING_SIZE to 64."
alexc
parents:
11426
diff
changeset
|
435 * 32 or 64 bit at once and could read over the end.<br> |
4794 | 436 * Note: If the first 23 bits of the additional bytes are not 0, then damaged |
437 * MPEG bitstreams could cause overread and segfault. | |
842
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
438 */ |
11438
db5623d197a3
Revert r22288 "Increase FF_INPUT_BUFFER_PADDING_SIZE to 64."
alexc
parents:
11426
diff
changeset
|
439 #define FF_INPUT_BUFFER_PADDING_SIZE 8 |
842
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
440 |
2422 | 441 /** |
4794 | 442 * minimum encoding buffer size |
443 * Used to avoid some checks during header writing. | |
2422 | 444 */ |
445 #define FF_MIN_BUFFER_SIZE 16384 | |
446 | |
8520 | 447 |
6037 | 448 /** |
6038 | 449 * motion estimation type. |
6037 | 450 */ |
320
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
451 enum Motion_Est_ID { |
6043 | 452 ME_ZERO = 1, ///< no search, that is use 0,0 vector whenever one is needed |
320
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
453 ME_FULL, |
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
454 ME_LOG, |
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
455 ME_PHODS, |
6043 | 456 ME_EPZS, ///< enhanced predictive zonal search |
457 ME_X1, ///< reserved for experiments | |
458 ME_HEX, ///< hexagon based search | |
459 ME_UMH, ///< uneven multi-hexagon search | |
460 ME_ITER, ///< iterative search | |
7003 | 461 ME_TESA, ///< transformed exhaustive search algorithm |
320
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
462 }; |
cda7d0857baf
- ME setting moved to AVCodecContext/MpegEncContext, no longer a global.
pulento
parents:
317
diff
changeset
|
463 |
2792 | 464 enum AVDiscard{ |
4794 | 465 /* We leave some space between them for extensions (drop some |
466 * keyframes for intra-only or drop just some bidir frames). */ | |
2792 | 467 AVDISCARD_NONE =-16, ///< discard nothing |
468 AVDISCARD_DEFAULT= 0, ///< discard useless packets like 0 size packets in avi | |
469 AVDISCARD_NONREF = 8, ///< discard all non reference | |
470 AVDISCARD_BIDIR = 16, ///< discard all bidirectional frames | |
471 AVDISCARD_NONKEY = 32, ///< discard all frames except keyframes | |
472 AVDISCARD_ALL = 48, ///< discard all | |
473 }; | |
474 | |
9600 | 475 enum AVColorPrimaries{ |
476 AVCOL_PRI_BT709 =1, ///< also ITU-R BT1361 / IEC 61966-2-4 / SMPTE RP177 Annex B | |
477 AVCOL_PRI_UNSPECIFIED=2, | |
478 AVCOL_PRI_BT470M =4, | |
479 AVCOL_PRI_BT470BG =5, ///< also ITU-R BT601-6 625 / ITU-R BT1358 625 / ITU-R BT1700 625 PAL & SECAM | |
480 AVCOL_PRI_SMPTE170M =6, ///< also ITU-R BT601-6 525 / ITU-R BT1358 525 / ITU-R BT1700 NTSC | |
481 AVCOL_PRI_SMPTE240M =7, ///< functionally identical to above | |
482 AVCOL_PRI_FILM =8, | |
483 AVCOL_PRI_NB , ///< Not part of ABI | |
484 }; | |
485 | |
486 enum AVColorTransferCharacteristic{ | |
487 AVCOL_TRC_BT709 =1, ///< also ITU-R BT1361 | |
488 AVCOL_TRC_UNSPECIFIED=2, | |
489 AVCOL_TRC_GAMMA22 =4, ///< also ITU-R BT470M / ITU-R BT1700 625 PAL & SECAM | |
490 AVCOL_TRC_GAMMA28 =5, ///< also ITU-R BT470BG | |
491 AVCOL_TRC_NB , ///< Not part of ABI | |
492 }; | |
493 | |
494 enum AVColorSpace{ | |
495 AVCOL_SPC_RGB =0, | |
496 AVCOL_SPC_BT709 =1, ///< also ITU-R BT1361 / IEC 61966-2-4 xvYCC709 / SMPTE RP177 Annex B | |
497 AVCOL_SPC_UNSPECIFIED=2, | |
498 AVCOL_SPC_FCC =4, | |
499 AVCOL_SPC_BT470BG =5, ///< also ITU-R BT601-6 625 / ITU-R BT1358 625 / ITU-R BT1700 625 PAL & SECAM / IEC 61966-2-4 xvYCC601 | |
500 AVCOL_SPC_SMPTE170M =6, ///< also ITU-R BT601-6 525 / ITU-R BT1358 525 / ITU-R BT1700 NTSC / functionally identical to above | |
501 AVCOL_SPC_SMPTE240M =7, | |
502 AVCOL_SPC_NB , ///< Not part of ABI | |
503 }; | |
504 | |
505 enum AVColorRange{ | |
506 AVCOL_RANGE_UNSPECIFIED=0, | |
507 AVCOL_RANGE_MPEG =1, ///< the normal 219*2^(n-8) "MPEG" YUV ranges | |
508 AVCOL_RANGE_JPEG =2, ///< the normal 2^n-1 "JPEG" YUV ranges | |
509 AVCOL_RANGE_NB , ///< Not part of ABI | |
510 }; | |
511 | |
9626
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
512 /** |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
513 * X X 3 4 X X are luma samples, |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
514 * 1 2 1-6 are possible chroma positions |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
515 * X X 5 6 X 0 is undefined/unknown position |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
516 */ |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
517 enum AVChromaLocation{ |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
518 AVCHROMA_LOC_UNSPECIFIED=0, |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
519 AVCHROMA_LOC_LEFT =1, ///< mpeg2/4, h264 default |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
520 AVCHROMA_LOC_CENTER =2, ///< mpeg1, jpeg, h263 |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
521 AVCHROMA_LOC_TOPLEFT =3, ///< DV |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
522 AVCHROMA_LOC_TOP =4, |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
523 AVCHROMA_LOC_BOTTOMLEFT =5, |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
524 AVCHROMA_LOC_BOTTOM =6, |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
525 AVCHROMA_LOC_NB , ///< Not part of ABI |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
526 }; |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
527 |
613 | 528 typedef struct RcOverride{ |
529 int start_frame; | |
530 int end_frame; | |
4794 | 531 int qscale; // If this is 0 then quality_factor will be used instead. |
613 | 532 float quality_factor; |
533 } RcOverride; | |
534 | |
3132
f16ccfe674cc
Increase maximum number of B-frames, necessary for H.264 encoding.
diego
parents:
3129
diff
changeset
|
535 #define FF_MAX_B_FRAMES 16 |
324 | 536 |
681 | 537 /* encoding support |
4794 | 538 These flags can be passed in AVCodecContext.flags before initialization. |
539 Note: Not everything is supported yet. | |
681 | 540 */ |
0 | 541 |
4794 | 542 #define CODEC_FLAG_QSCALE 0x0002 ///< Use fixed qscale. |
543 #define CODEC_FLAG_4MV 0x0004 ///< 4 MV per MB allowed / advanced prediction for H.263. | |
544 #define CODEC_FLAG_QPEL 0x0010 ///< Use qpel MC. | |
545 #define CODEC_FLAG_GMC 0x0020 ///< Use GMC. | |
546 #define CODEC_FLAG_MV0 0x0040 ///< Always try a MB with MV=<0,0>. | |
547 #define CODEC_FLAG_PART 0x0080 ///< Use data partitioning. | |
6039 | 548 /** |
549 * The parent program guarantees that the input for B-frames containing | |
4794 | 550 * streams is not written to for at least s->max_b_frames+1 frames, if |
6039 | 551 * this is not set the input will be copied. |
552 */ | |
329 | 553 #define CODEC_FLAG_INPUT_PRESERVED 0x0100 |
5590 | 554 #define CODEC_FLAG_PASS1 0x0200 ///< Use internal 2pass ratecontrol in first pass mode. |
555 #define CODEC_FLAG_PASS2 0x0400 ///< Use internal 2pass ratecontrol in second pass mode. | |
556 #define CODEC_FLAG_EXTERN_HUFF 0x1000 ///< Use external Huffman table (for MJPEG). | |
557 #define CODEC_FLAG_GRAY 0x2000 ///< Only decode/encode grayscale. | |
558 #define CODEC_FLAG_EMU_EDGE 0x4000 ///< Don't draw edges. | |
559 #define CODEC_FLAG_PSNR 0x8000 ///< error[?] variables will be set during encoding. | |
560 #define CODEC_FLAG_TRUNCATED 0x00010000 /** Input bitstream might be truncated at a random | |
561 location instead of only at frame boundaries. */ | |
4794 | 562 #define CODEC_FLAG_NORMALIZE_AQP 0x00020000 ///< Normalize adaptive quantization. |
563 #define CODEC_FLAG_INTERLACED_DCT 0x00040000 ///< Use interlaced DCT. | |
564 #define CODEC_FLAG_LOW_DELAY 0x00080000 ///< Force low delay. | |
565 #define CODEC_FLAG_ALT_SCAN 0x00100000 ///< Use alternate scan. | |
566 #define CODEC_FLAG_GLOBAL_HEADER 0x00400000 ///< Place global headers in extradata instead of every keyframe. | |
567 #define CODEC_FLAG_BITEXACT 0x00800000 ///< Use only bitexact stuff (except (I)DCT). | |
1095
c7604e6291c5
extended option for h263+ patch by (fixounet at free dot fr) with some minor modifications
michaelni
parents:
1092
diff
changeset
|
568 /* Fx : Flag for h263+ extra options */ |
4794 | 569 #define CODEC_FLAG_AC_PRED 0x01000000 ///< H.263 advanced intra coding / MPEG-4 AC prediction |
570 #define CODEC_FLAG_H263P_UMV 0x02000000 ///< unlimited motion vector | |
571 #define CODEC_FLAG_CBP_RD 0x04000000 ///< Use rate distortion optimization for cbp. | |
572 #define CODEC_FLAG_QP_RD 0x08000000 ///< Use rate distortion optimization for qp selectioon. | |
573 #define CODEC_FLAG_H263P_AIV 0x00000008 ///< H.263 alternative inter VLC | |
1644 | 574 #define CODEC_FLAG_OBMC 0x00000001 ///< OBMC |
575 #define CODEC_FLAG_LOOP_FILTER 0x00000800 ///< loop filter | |
1708 | 576 #define CODEC_FLAG_H263P_SLICE_STRUCT 0x10000000 |
577 #define CODEC_FLAG_INTERLACED_ME 0x20000000 ///< interlaced motion estimation | |
4794 | 578 #define CODEC_FLAG_SVCD_SCAN_OFFSET 0x40000000 ///< Will reserve space for SVCD scan offset user data. |
6541 | 579 #define CODEC_FLAG_CLOSED_GOP 0x80000000 |
4794 | 580 #define CODEC_FLAG2_FAST 0x00000001 ///< Allow non spec compliant speedup tricks. |
581 #define CODEC_FLAG2_STRICT_GOP 0x00000002 ///< Strictly enforce GOP size. | |
582 #define CODEC_FLAG2_NO_OUTPUT 0x00000004 ///< Skip bitstream encoding. | |
583 #define CODEC_FLAG2_LOCAL_HEADER 0x00000008 ///< Place global headers at every keyframe instead of in extradata. | |
584 #define CODEC_FLAG2_BPYRAMID 0x00000010 ///< H.264 allow B-frames to be used as references. | |
585 #define CODEC_FLAG2_WPRED 0x00000020 ///< H.264 weighted biprediction for B-frames | |
4273
73abe5df48ea
Add "mixed_refs" description suggested by Loren Merritt and update accompanying
takis
parents:
4263
diff
changeset
|
586 #define CODEC_FLAG2_MIXED_REFS 0x00000040 ///< H.264 one reference per partition, as opposed to one reference per macroblock |
2996 | 587 #define CODEC_FLAG2_8X8DCT 0x00000080 ///< H.264 high profile 8x8 transform |
588 #define CODEC_FLAG2_FASTPSKIP 0x00000100 ///< H.264 fast pskip | |
589 #define CODEC_FLAG2_AUD 0x00000200 ///< H.264 access unit delimiters | |
4794 | 590 #define CODEC_FLAG2_BRDO 0x00000400 ///< B-frame rate-distortion optimization |
591 #define CODEC_FLAG2_INTRA_VLC 0x00000800 ///< Use MPEG-2 intra VLC table. | |
592 #define CODEC_FLAG2_MEMC_ONLY 0x00001000 ///< Only do ME/MC (I frames -> ref, P frame -> ME+MC). | |
593 #define CODEC_FLAG2_DROP_FRAME_TIMECODE 0x00002000 ///< timecode is in drop frame format. | |
594 #define CODEC_FLAG2_SKIP_RD 0x00004000 ///< RD optimal MB level residual skipping | |
595 #define CODEC_FLAG2_CHUNKS 0x00008000 ///< Input bitstream might be truncated at a packet boundaries instead of only at frame boundaries. | |
596 #define CODEC_FLAG2_NON_LINEAR_QUANT 0x00010000 ///< Use MPEG-2 nonlinear quantizer. | |
6346
11a44fc273a5
Add 'reservoir' flag to lavc's flags2 controlling whether or not codes may
andoma
parents:
6337
diff
changeset
|
597 #define CODEC_FLAG2_BIT_RESERVOIR 0x00020000 ///< Use a bit reservoir when encoding if possible |
10658 | 598 #define CODEC_FLAG2_MBTREE 0x00040000 ///< Use macroblock tree ratecontrol (x264 only) |
11538
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
599 #define CODEC_FLAG2_PSY 0x00080000 ///< Use psycho visual optimizations. |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
600 #define CODEC_FLAG2_SSIM 0x00100000 ///< Compute SSIM during encoding, error[] values are undefined. |
11689
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
601 #define CODEC_FLAG2_INTRA_REFRESH 0x00200000 ///< Use periodic insertion of intra blocks instead of keyframes. |
2201 | 602 |
1095
c7604e6291c5
extended option for h263+ patch by (fixounet at free dot fr) with some minor modifications
michaelni
parents:
1092
diff
changeset
|
603 /* Unsupported options : |
2979 | 604 * Syntax Arithmetic coding (SAC) |
605 * Reference Picture Selection | |
4588
fc155ff94878
cosmetics: Fix another common typo, dependAnt --> dependEnt.
diego
parents:
4583
diff
changeset
|
606 * Independent Segment Decoding */ |
1095
c7604e6291c5
extended option for h263+ patch by (fixounet at free dot fr) with some minor modifications
michaelni
parents:
1092
diff
changeset
|
607 /* /Fx */ |
67 | 608 /* codec capabilities */ |
609 | |
4794 | 610 #define CODEC_CAP_DRAW_HORIZ_BAND 0x0001 ///< Decoder can use draw_horiz_band callback. |
1192 | 611 /** |
11545 | 612 * Codec uses get_buffer() for allocating buffers and supports custom allocators. |
613 * If not set, it might not use get_buffer() at all or use operations that | |
614 * assume the buffer was allocated by avcodec_default_get_buffer. | |
1192 | 615 */ |
616 #define CODEC_CAP_DR1 0x0002 | |
4794 | 617 /* If 'parse_only' field is true, then avcodec_parse_frame() can be used. */ |
581
8adda0af04e2
added proposed API for parse_only mode to extract compressed frames from compressed streams
bellard
parents:
573
diff
changeset
|
618 #define CODEC_CAP_PARSE_ONLY 0x0004 |
842
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
619 #define CODEC_CAP_TRUNCATED 0x0008 |
4794 | 620 /* Codec can export data for HW decoding (XvMC). */ |
1848
c72589baee53
initial chroma_format changes,xvmc tweaks and codec_cap
iive
parents:
1840
diff
changeset
|
621 #define CODEC_CAP_HWACCEL 0x0010 |
2967 | 622 /** |
4794 | 623 * Codec has a nonzero delay and needs to be fed with NULL at the end to get the delayed data. |
624 * If this is not set, the codec is guaranteed to never be fed with NULL data. | |
2453 | 625 */ |
2091 | 626 #define CODEC_CAP_DELAY 0x0020 |
3352
608659b58523
CODEC_CAP_SMALL_LAST_FRAME patch by Justin Ruggles jruggle earthlink net
michael
parents:
3349
diff
changeset
|
627 /** |
608659b58523
CODEC_CAP_SMALL_LAST_FRAME patch by Justin Ruggles jruggle earthlink net
michael
parents:
3349
diff
changeset
|
628 * Codec can be fed a final frame with a smaller size. |
608659b58523
CODEC_CAP_SMALL_LAST_FRAME patch by Justin Ruggles jruggle earthlink net
michael
parents:
3349
diff
changeset
|
629 * This can be used to prevent truncation of the last audio samples. |
608659b58523
CODEC_CAP_SMALL_LAST_FRAME patch by Justin Ruggles jruggle earthlink net
michael
parents:
3349
diff
changeset
|
630 */ |
608659b58523
CODEC_CAP_SMALL_LAST_FRAME patch by Justin Ruggles jruggle earthlink net
michael
parents:
3349
diff
changeset
|
631 #define CODEC_CAP_SMALL_LAST_FRAME 0x0040 |
8522
f8c091bb5779
Add VDPAU hardware accelerated decoding for H264 which can be used by
cehoyos
parents:
8521
diff
changeset
|
632 /** |
f8c091bb5779
Add VDPAU hardware accelerated decoding for H264 which can be used by
cehoyos
parents:
8521
diff
changeset
|
633 * Codec can export data for HW decoding (VDPAU). |
f8c091bb5779
Add VDPAU hardware accelerated decoding for H264 which can be used by
cehoyos
parents:
8521
diff
changeset
|
634 */ |
f8c091bb5779
Add VDPAU hardware accelerated decoding for H264 which can be used by
cehoyos
parents:
8521
diff
changeset
|
635 #define CODEC_CAP_HWACCEL_VDPAU 0x0080 |
10180
a514a601bf26
Add CODEC_CAP_SUBFRAMES for codecs that output multiple subframes
faust3
parents:
10158
diff
changeset
|
636 /** |
a514a601bf26
Add CODEC_CAP_SUBFRAMES for codecs that output multiple subframes
faust3
parents:
10158
diff
changeset
|
637 * Codec can output multiple frames per AVPacket |
10957 | 638 * Normally demuxers return one frame at a time, demuxers which do not do |
639 * are connected to a parser to split what they return into proper frames. | |
640 * This flag is reserved to the very rare category of codecs which have a | |
641 * bitstream that cannot be split into frames without timeconsuming | |
642 * operations like full decoding. Demuxers carring such bitstreams thus | |
643 * may return multiple frames in a packet. This has many disadvantages like | |
644 * prohibiting stream copy in many cases thus it should only be considered | |
645 * as a last resort. | |
10180
a514a601bf26
Add CODEC_CAP_SUBFRAMES for codecs that output multiple subframes
faust3
parents:
10158
diff
changeset
|
646 */ |
a514a601bf26
Add CODEC_CAP_SUBFRAMES for codecs that output multiple subframes
faust3
parents:
10158
diff
changeset
|
647 #define CODEC_CAP_SUBFRAMES 0x0100 |
11771
3c0dffc64d86
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
cehoyos
parents:
11770
diff
changeset
|
648 /** |
3c0dffc64d86
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
cehoyos
parents:
11770
diff
changeset
|
649 * Codec is experimental and is thus avoided in favor of non experimental |
3c0dffc64d86
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
cehoyos
parents:
11770
diff
changeset
|
650 * encoders |
3c0dffc64d86
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
cehoyos
parents:
11770
diff
changeset
|
651 */ |
3c0dffc64d86
Add CODEC_CAP_EXPERIMENTAL and prefer encoders without it.
cehoyos
parents:
11770
diff
changeset
|
652 #define CODEC_CAP_EXPERIMENTAL 0x0200 |
67 | 653 |
4794 | 654 //The following defines may change, don't expect compatibility if you use them. |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
655 #define MB_TYPE_INTRA4x4 0x0001 |
4794 | 656 #define MB_TYPE_INTRA16x16 0x0002 //FIXME H.264-specific |
657 #define MB_TYPE_INTRA_PCM 0x0004 //FIXME H.264-specific | |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
658 #define MB_TYPE_16x16 0x0008 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
659 #define MB_TYPE_16x8 0x0010 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
660 #define MB_TYPE_8x16 0x0020 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
661 #define MB_TYPE_8x8 0x0040 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
662 #define MB_TYPE_INTERLACED 0x0080 |
5590 | 663 #define MB_TYPE_DIRECT2 0x0100 //FIXME |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
664 #define MB_TYPE_ACPRED 0x0200 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
665 #define MB_TYPE_GMC 0x0400 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
666 #define MB_TYPE_SKIP 0x0800 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
667 #define MB_TYPE_P0L0 0x1000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
668 #define MB_TYPE_P1L0 0x2000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
669 #define MB_TYPE_P0L1 0x4000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
670 #define MB_TYPE_P1L1 0x8000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
671 #define MB_TYPE_L0 (MB_TYPE_P0L0 | MB_TYPE_P1L0) |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
672 #define MB_TYPE_L1 (MB_TYPE_P0L1 | MB_TYPE_P1L1) |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
673 #define MB_TYPE_L0L1 (MB_TYPE_L0 | MB_TYPE_L1) |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
674 #define MB_TYPE_QUANT 0x00010000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
675 #define MB_TYPE_CBP 0x00020000 |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
676 //Note bits 24-31 are reserved for codec specific use (h264 ref0, mpeg1 0mv, ...) |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
677 |
1546 | 678 /** |
679 * Pan Scan area. | |
4794 | 680 * This specifies the area which should be displayed. |
681 * Note there may be multiple such areas for one frame. | |
1546 | 682 */ |
683 typedef struct AVPanScan{ | |
684 /** | |
4794 | 685 * id |
686 * - encoding: Set by user. | |
687 * - decoding: Set by libavcodec. | |
1546 | 688 */ |
689 int id; | |
690 | |
691 /** | |
692 * width and height in 1/16 pel | |
4794 | 693 * - encoding: Set by user. |
694 * - decoding: Set by libavcodec. | |
1546 | 695 */ |
696 int width; | |
697 int height; | |
698 | |
699 /** | |
4794 | 700 * position of the top left corner in 1/16 pel for up to 3 fields/frames |
701 * - encoding: Set by user. | |
702 * - decoding: Set by libavcodec. | |
1546 | 703 */ |
704 int16_t position[3][2]; | |
705 }AVPanScan; | |
706 | |
925 | 707 #define FF_COMMON_FRAME \ |
1138 | 708 /**\ |
709 * pointer to the picture planes.\ | |
4794 | 710 * This might be different from the first allocated byte\ |
1138 | 711 * - encoding: \ |
712 * - decoding: \ | |
713 */\ | |
903 | 714 uint8_t *data[4];\ |
715 int linesize[4];\ | |
716 /**\ | |
4794 | 717 * pointer to the first allocated byte of the picture. Can be used in get_buffer/release_buffer.\ |
718 * This isn't used by libavcodec unless the default get/release_buffer() is used.\ | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
719 * - encoding: \ |
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
720 * - decoding: \ |
903 | 721 */\ |
722 uint8_t *base[4];\ | |
723 /**\ | |
724 * 1 -> keyframe, 0-> not\ | |
4794 | 725 * - encoding: Set by libavcodec.\ |
726 * - decoding: Set by libavcodec.\ | |
903 | 727 */\ |
728 int key_frame;\ | |
729 \ | |
730 /**\ | |
4794 | 731 * Picture type of the frame, see ?_TYPE below.\ |
732 * - encoding: Set by libavcodec. for coded_picture (and set by user for input).\ | |
733 * - decoding: Set by libavcodec.\ | |
903 | 734 */\ |
735 int pict_type;\ | |
736 \ | |
737 /**\ | |
2637 | 738 * presentation timestamp in time_base units (time when frame should be shown to user)\ |
4794 | 739 * If AV_NOPTS_VALUE then frame_rate = 1/time_base will be assumed.\ |
740 * - encoding: MUST be set by user.\ | |
741 * - decoding: Set by libavcodec.\ | |
903 | 742 */\ |
1172
9d257357ce07
fix pts type in avcodec.h for WIN32 patch by (Richard Hodges <rh at matriplex dot com>)
michaelni
parents:
1168
diff
changeset
|
743 int64_t pts;\ |
903 | 744 \ |
745 /**\ | |
4794 | 746 * picture number in bitstream order\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
747 * - encoding: set by\ |
4794 | 748 * - decoding: Set by libavcodec.\ |
903 | 749 */\ |
750 int coded_picture_number;\ | |
751 /**\ | |
4794 | 752 * picture number in display order\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
753 * - encoding: set by\ |
4794 | 754 * - decoding: Set by libavcodec.\ |
903 | 755 */\ |
756 int display_picture_number;\ | |
757 \ | |
758 /**\ | |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
759 * quality (between 1 (good) and FF_LAMBDA_MAX (bad)) \ |
4794 | 760 * - encoding: Set by libavcodec. for coded_picture (and set by user for input).\ |
761 * - decoding: Set by libavcodec.\ | |
903 | 762 */\ |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
763 int quality; \ |
903 | 764 \ |
765 /**\ | |
766 * buffer age (1->was last buffer and dint change, 2->..., ...).\ | |
4794 | 767 * Set to INT_MAX if the buffer has not been used yet.\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
768 * - encoding: unused\ |
4794 | 769 * - decoding: MUST be set by get_buffer().\ |
903 | 770 */\ |
771 int age;\ | |
772 \ | |
773 /**\ | |
774 * is this picture used as reference\ | |
6514
77de2a1737d4
More complete documentation for AVFrame.reference.
michael
parents:
6508
diff
changeset
|
775 * The values for this are the same as the MpegEncContext.picture_structure\ |
77de2a1737d4
More complete documentation for AVFrame.reference.
michael
parents:
6508
diff
changeset
|
776 * variable, that is 1->top field, 2->bottom field, 3->frame/both fields.\ |
9050 | 777 * Set to 4 for delayed, non-reference frames.\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
778 * - encoding: unused\ |
4794 | 779 * - decoding: Set by libavcodec. (before get_buffer() call)).\ |
903 | 780 */\ |
781 int reference;\ | |
782 \ | |
783 /**\ | |
784 * QP table\ | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
785 * - encoding: unused\ |
4794 | 786 * - decoding: Set by libavcodec.\ |
903 | 787 */\ |
788 int8_t *qscale_table;\ | |
789 /**\ | |
790 * QP store stride\ | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
791 * - encoding: unused\ |
4794 | 792 * - decoding: Set by libavcodec.\ |
903 | 793 */\ |
794 int qstride;\ | |
795 \ | |
796 /**\ | |
4794 | 797 * mbskip_table[mb]>=1 if MB didn't change\ |
903 | 798 * stride= mb_width = (width+15)>>4\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
799 * - encoding: unused\ |
4794 | 800 * - decoding: Set by libavcodec.\ |
903 | 801 */\ |
802 uint8_t *mbskip_table;\ | |
803 \ | |
804 /**\ | |
4794 | 805 * motion vector table\ |
2397 | 806 * @code\ |
807 * example:\ | |
808 * int mv_sample_log2= 4 - motion_subsample_log2;\ | |
809 * int mb_width= (width+15)>>4;\ | |
810 * int mv_stride= (mb_width << mv_sample_log2) + 1;\ | |
811 * motion_val[direction][x + y*mv_stride][0->mv_x, 1->mv_y];\ | |
812 * @endcode\ | |
4794 | 813 * - encoding: Set by user.\ |
814 * - decoding: Set by libavcodec.\ | |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
815 */\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
816 int16_t (*motion_val[2])[2];\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
817 \ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
818 /**\ |
4794 | 819 * macroblock type table\ |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
820 * mb_type_base + mb_width + 2\ |
4794 | 821 * - encoding: Set by user.\ |
822 * - decoding: Set by libavcodec.\ | |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
823 */\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
824 uint32_t *mb_type;\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
825 \ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
826 /**\ |
2394 | 827 * log2 of the size of the block which a single vector in motion_val represents: \ |
828 * (4->16x16, 3->8x8, 2-> 4x4, 1-> 2x2)\ | |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
829 * - encoding: unused\ |
4794 | 830 * - decoding: Set by libavcodec.\ |
1668
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
831 */\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
832 uint8_t motion_subsample_log2;\ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
833 \ |
30746f429df6
move motion_val & mb_type to AVFrame patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1661
diff
changeset
|
834 /**\ |
903 | 835 * for some private data of the user\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
836 * - encoding: unused\ |
4794 | 837 * - decoding: Set by user.\ |
903 | 838 */\ |
839 void *opaque;\ | |
909
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
840 \ |
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
841 /**\ |
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
842 * error\ |
4794 | 843 * - encoding: Set by libavcodec. if flags&CODEC_FLAG_PSNR.\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
844 * - decoding: unused\ |
909
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
845 */\ |
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
846 uint64_t error[4];\ |
924 | 847 \ |
848 /**\ | |
4794 | 849 * type of the buffer (to keep track of who has to deallocate data[*])\ |
850 * - encoding: Set by the one who allocates it.\ | |
851 * - decoding: Set by the one who allocates it.\ | |
852 * Note: User allocated (direct rendering) & internal buffers cannot coexist currently.\ | |
924 | 853 */\ |
854 int type;\ | |
1085
9acf4b552047
move repeat_pict field from AVCodecContext -> AVFrame (closes bug #683536)
michaelni
parents:
1084
diff
changeset
|
855 \ |
9acf4b552047
move repeat_pict field from AVCodecContext -> AVFrame (closes bug #683536)
michaelni
parents:
1084
diff
changeset
|
856 /**\ |
4794 | 857 * When decoding, this signals how much the picture must be delayed.\ |
1085
9acf4b552047
move repeat_pict field from AVCodecContext -> AVFrame (closes bug #683536)
michaelni
parents:
1084
diff
changeset
|
858 * extra_delay = repeat_pict / (2*fps)\ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
859 * - encoding: unused\ |
4794 | 860 * - decoding: Set by libavcodec.\ |
1085
9acf4b552047
move repeat_pict field from AVCodecContext -> AVFrame (closes bug #683536)
michaelni
parents:
1084
diff
changeset
|
861 */\ |
1196 | 862 int repeat_pict;\ |
863 \ | |
864 /**\ | |
865 * \ | |
866 */\ | |
867 int qscale_type;\ | |
1543
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
868 \ |
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
869 /**\ |
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
870 * The content of the picture is interlaced.\ |
4794 | 871 * - encoding: Set by user.\ |
872 * - decoding: Set by libavcodec. (default 0)\ | |
1543
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
873 */\ |
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
874 int interlaced_frame;\ |
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
875 \ |
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
876 /**\ |
4794 | 877 * If the content is interlaced, is top field displayed first.\ |
878 * - encoding: Set by user.\ | |
879 * - decoding: Set by libavcodec.\ | |
1543
7542cb99b950
* providing MPEG codecs with a generic fields in AVFrame to use.
romansh
parents:
1535
diff
changeset
|
880 */\ |
1547 | 881 int top_field_first;\ |
1546 | 882 \ |
883 /**\ | |
884 * Pan scan.\ | |
4794 | 885 * - encoding: Set by user.\ |
886 * - decoding: Set by libavcodec.\ | |
1546 | 887 */\ |
888 AVPanScan *pan_scan;\ | |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
889 \ |
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
890 /**\ |
4794 | 891 * Tell user application that palette has changed from previous frame.\ |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
892 * - encoding: ??? (no palette-enabled encoder yet)\ |
4794 | 893 * - decoding: Set by libavcodec. (default 0).\ |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
894 */\ |
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
895 int palette_has_changed;\ |
1606 | 896 \ |
897 /**\ | |
4794 | 898 * codec suggestion on buffer type if != 0\ |
1606 | 899 * - encoding: unused\ |
4794 | 900 * - decoding: Set by libavcodec. (before get_buffer() call)).\ |
1606 | 901 */\ |
902 int buffer_hints;\ | |
1833
ba27ce284d07
export DCT coefficients patch by (Wolfgang Hesseler <wolfgang.hesseler at imk dot fraunhofer dot de>)
michael
parents:
1832
diff
changeset
|
903 \ |
ba27ce284d07
export DCT coefficients patch by (Wolfgang Hesseler <wolfgang.hesseler at imk dot fraunhofer dot de>)
michael
parents:
1832
diff
changeset
|
904 /**\ |
4794 | 905 * DCT coefficients\ |
1833
ba27ce284d07
export DCT coefficients patch by (Wolfgang Hesseler <wolfgang.hesseler at imk dot fraunhofer dot de>)
michael
parents:
1832
diff
changeset
|
906 * - encoding: unused\ |
4794 | 907 * - decoding: Set by libavcodec.\ |
1833
ba27ce284d07
export DCT coefficients patch by (Wolfgang Hesseler <wolfgang.hesseler at imk dot fraunhofer dot de>)
michael
parents:
1832
diff
changeset
|
908 */\ |
ba27ce284d07
export DCT coefficients patch by (Wolfgang Hesseler <wolfgang.hesseler at imk dot fraunhofer dot de>)
michael
parents:
1832
diff
changeset
|
909 short *dct_coeff;\ |
1945
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
910 \ |
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
911 /**\ |
11299 | 912 * motion reference frame index\ |
913 * the order in which these are stored can depend on the codec.\ | |
4794 | 914 * - encoding: Set by user.\ |
915 * - decoding: Set by libavcodec.\ | |
1945
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
916 */\ |
7631
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
917 int8_t *ref_index[2];\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
918 \ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
919 /**\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
920 * reordered opaque 64bit number (generally a PTS) from AVCodecContext.reordered_opaque\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
921 * output in AVFrame.reordered_opaque\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
922 * - encoding: unused\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
923 * - decoding: Read by user.\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
924 */\ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
925 int64_t reordered_opaque;\ |
9155 | 926 \ |
927 /**\ | |
928 * hardware accelerator private data (FFmpeg allocated)\ | |
929 * - encoding: unused\ | |
930 * - decoding: Set by libavcodec\ | |
931 */\ | |
9200
7b62de9c383d
Rename hwaccel_data_private to hwaccel_picture_private.
gb
parents:
9190
diff
changeset
|
932 void *hwaccel_picture_private;\ |
7631
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
933 |
1085
9acf4b552047
move repeat_pict field from AVCodecContext -> AVFrame (closes bug #683536)
michaelni
parents:
1084
diff
changeset
|
934 |
2979 | 935 #define FF_QSCALE_TYPE_MPEG1 0 |
936 #define FF_QSCALE_TYPE_MPEG2 1 | |
937 #define FF_QSCALE_TYPE_H264 2 | |
11053
c57e72227d7d
Make VP5 and VP6 decoders output a qscale table to allow for more automatic
reimar
parents:
11047
diff
changeset
|
938 #define FF_QSCALE_TYPE_VP56 3 |
924 | 939 |
940 #define FF_BUFFER_TYPE_INTERNAL 1 | |
4794 | 941 #define FF_BUFFER_TYPE_USER 2 ///< direct rendering buffers (image is (de)allocated by user) |
942 #define FF_BUFFER_TYPE_SHARED 4 ///< Buffer from somewhere else; don't deallocate image (data/base), all other tables are not shared. | |
943 #define FF_BUFFER_TYPE_COPY 8 ///< Just a (modified) copy of some other buffer, don't deallocate anything. | |
924 | 944 |
903 | 945 |
6457
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
946 #define FF_I_TYPE 1 ///< Intra |
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
947 #define FF_P_TYPE 2 ///< Predicted |
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
948 #define FF_B_TYPE 3 ///< Bi-dir predicted |
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
949 #define FF_S_TYPE 4 ///< S(GMC)-VOP MPEG4 |
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
950 #define FF_SI_TYPE 5 ///< Switching Intra |
f88fc47e8e46
doxyfy frame type comments and add some more comments
aurel
parents:
6456
diff
changeset
|
951 #define FF_SP_TYPE 6 ///< Switching Predicted |
6456 | 952 #define FF_BI_TYPE 7 |
903 | 953 |
4794 | 954 #define FF_BUFFER_HINTS_VALID 0x01 // Buffer hints value is meaningful (if 0 ignore). |
955 #define FF_BUFFER_HINTS_READABLE 0x02 // Codec will read from buffer. | |
956 #define FF_BUFFER_HINTS_PRESERVE 0x04 // User must not alter buffer content. | |
957 #define FF_BUFFER_HINTS_REUSABLE 0x08 // Codec will reuse the buffer (update). | |
1606 | 958 |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
959 typedef struct AVPacket { |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
960 /** |
9359
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
961 * Presentation timestamp in AVStream->time_base units; the time at which |
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
962 * the decompressed packet will be presented to the user. |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
963 * Can be AV_NOPTS_VALUE if it is not stored in the file. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
964 * pts MUST be larger or equal to dts as presentation cannot happen before |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
965 * decompression, unless one wants to view hex dumps. Some formats misuse |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
966 * the terms dts and pts/cts to mean something different. Such timestamps |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
967 * must be converted to true pts/dts before they are stored in AVPacket. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
968 */ |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
969 int64_t pts; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
970 /** |
9359
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
971 * Decompression timestamp in AVStream->time_base units; the time at which |
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
972 * the packet is decompressed. |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
973 * Can be AV_NOPTS_VALUE if it is not stored in the file. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
974 */ |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
975 int64_t dts; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
976 uint8_t *data; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
977 int size; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
978 int stream_index; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
979 int flags; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
980 /** |
9359
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
981 * Duration of this packet in AVStream->time_base units, 0 if unknown. |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
982 * Equals next_pts - this_pts in presentation order. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
983 */ |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
984 int duration; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
985 void (*destruct)(struct AVPacket *); |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
986 void *priv; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
987 int64_t pos; ///< byte position in stream, -1 if unknown |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
988 |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
989 /** |
9359
f978e4a699c5
Clarify which time_base the relevant members of AVPacket use
superdump
parents:
9357
diff
changeset
|
990 * Time difference in AVStream->time_base units from the pts of this |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
991 * packet to the point at which the output from the decoder has converged |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
992 * independent from the availability of previous frames. That is, the |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
993 * frames are virtually identical no matter if decoding started from |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
994 * the very first frame or from this keyframe. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
995 * Is AV_NOPTS_VALUE if unknown. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
996 * This field is not the display duration of the current packet. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
997 * |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
998 * The purpose of this field is to allow seeking in streams that have no |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
999 * keyframes in the conventional sense. It corresponds to the |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1000 * recovery point SEI in H.264 and match_time_delta in NUT. It is also |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1001 * essential for some types of subtitle streams to ensure that all |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1002 * subtitles are correctly displayed after seeking. |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1003 */ |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1004 int64_t convergence_duration; |
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1005 } AVPacket; |
9786 | 1006 #define AV_PKT_FLAG_KEY 0x0001 |
1007 #if LIBAVCODEC_VERSION_MAJOR < 53 | |
1008 #define PKT_FLAG_KEY AV_PKT_FLAG_KEY | |
1009 #endif | |
9354
174309386512
Move AVPacket up a bit, so that structs/functions that include AVPacket can
rbultje
parents:
9351
diff
changeset
|
1010 |
1168 | 1011 /** |
1012 * Audio Video Frame. | |
6049
7fb5a3652990
Document a few more structure change rules with relation to ABI/API.
michael
parents:
6048
diff
changeset
|
1013 * New fields can be added to the end of FF_COMMON_FRAME with minor version |
7fb5a3652990
Document a few more structure change rules with relation to ABI/API.
michael
parents:
6048
diff
changeset
|
1014 * bumps. |
6055 | 1015 * Removal, reordering and changes to existing fields require a major |
6049
7fb5a3652990
Document a few more structure change rules with relation to ABI/API.
michael
parents:
6048
diff
changeset
|
1016 * version bump. No fields should be added into AVFrame before or after |
7fb5a3652990
Document a few more structure change rules with relation to ABI/API.
michael
parents:
6048
diff
changeset
|
1017 * FF_COMMON_FRAME! |
6055 | 1018 * sizeof(AVFrame) must not be used outside libav*. |
1168 | 1019 */ |
925 | 1020 typedef struct AVFrame { |
1021 FF_COMMON_FRAME | |
1022 } AVFrame; | |
903 | 1023 |
1105 | 1024 /** |
6048
0277500fe13d
Document structure change rules with relation to ABI/API.
michael
parents:
6047
diff
changeset
|
1025 * main external API structure. |
0277500fe13d
Document structure change rules with relation to ABI/API.
michael
parents:
6047
diff
changeset
|
1026 * New fields can be added to the end with minor version bumps. |
6055 | 1027 * Removal, reordering and changes to existing fields require a major |
6048
0277500fe13d
Document structure change rules with relation to ABI/API.
michael
parents:
6047
diff
changeset
|
1028 * version bump. |
6055 | 1029 * sizeof(AVCodecContext) must not be used outside libav*. |
1105 | 1030 */ |
0 | 1031 typedef struct AVCodecContext { |
684 | 1032 /** |
4794 | 1033 * information on struct for av_log |
1855
bafde44145f9
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1854
diff
changeset
|
1034 * - set by avcodec_alloc_context |
bafde44145f9
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1854
diff
changeset
|
1035 */ |
6464
0c3cc1d7a0b3
Make av_class a pointer to a const AVClass. Addresses one warning in
takis
parents:
6461
diff
changeset
|
1036 const AVClass *av_class; |
1855
bafde44145f9
av_log() patch by (Michel Bardiaux <mbardiaux at peaktime dot be>)
michael
parents:
1854
diff
changeset
|
1037 /** |
4794 | 1038 * the average bitrate |
1039 * - encoding: Set by user; unused for constant quantizer encoding. | |
1040 * - decoding: Set by libavcodec. 0 or some bitrate if this info is available in the stream. | |
684 | 1041 */ |
0 | 1042 int bit_rate; |
684 | 1043 |
1044 /** | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1045 * number of bits the bitstream is allowed to diverge from the reference. |
684 | 1046 * the reference can be CBR (for CBR pass1) or VBR (for pass2) |
4794 | 1047 * - encoding: Set by user; unused for constant quantizer encoding. |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1048 * - decoding: unused |
684 | 1049 */ |
2967 | 1050 int bit_rate_tolerance; |
684 | 1051 |
1052 /** | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1053 * CODEC_FLAG_*. |
4794 | 1054 * - encoding: Set by user. |
1055 * - decoding: Set by user. | |
684 | 1056 */ |
0 | 1057 int flags; |
684 | 1058 |
1059 /** | |
4794 | 1060 * Some codecs need additional format info. It is stored here. |
1061 * If any muxer uses this then ALL demuxers/parsers AND encoders for the | |
1062 * specific codec MUST set it correctly otherwise stream copy breaks. | |
1063 * In general use of this field by muxers is not recommanded. | |
1064 * - encoding: Set by libavcodec. | |
1065 * - decoding: Set by libavcodec. (FIXME: Is this OK?) | |
684 | 1066 */ |
1067 int sub_id; | |
1068 | |
1069 /** | |
4794 | 1070 * Motion estimation algorithm used for video coding. |
2996 | 1071 * 1 (zero), 2 (full), 3 (log), 4 (phods), 5 (epzs), 6 (x1), 7 (hex), |
7002
92c74bbdf4fb
add esa/dia compat me options and new tesa for libx264
bcoudurier
parents:
6993
diff
changeset
|
1072 * 8 (umh), 9 (iter), 10 (tesa) [7, 8, 10 are x264 specific, 9 is snow specific] |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1073 * - encoding: MUST be set by user. |
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1074 * - decoding: unused |
684 | 1075 */ |
1076 int me_method; | |
1077 | |
1078 /** | |
4794 | 1079 * some codecs need / can use extradata like Huffman tables. |
1080 * mjpeg: Huffman tables | |
684 | 1081 * rv10: additional flags |
747
3d4377531f6c
mpeg4 header parser clenup (needed for parsing of VOL header in avctx->extradata)
michaelni
parents:
745
diff
changeset
|
1082 * mpeg4: global headers (they can be in the bitstream or here) |
4794 | 1083 * The allocated memory should be FF_INPUT_BUFFER_PADDING_SIZE bytes larger |
1084 * than extradata_size to avoid prolems if it is read with the bitstream reader. | |
1085 * The bytewise contents of extradata must not depend on the architecture or CPU endianness. | |
1086 * - encoding: Set/allocated/freed by libavcodec. | |
1087 * - decoding: Set/allocated/freed by user. | |
684 | 1088 */ |
3930 | 1089 uint8_t *extradata; |
349
34f6c77ff01a
Support for external huffman table and various fixes by Alex Beregszaszi <alex@naxine.org>
arpi_esp
parents:
345
diff
changeset
|
1090 int extradata_size; |
2967 | 1091 |
684 | 1092 /** |
4794 | 1093 * This is the fundamental unit of time (in seconds) in terms |
1094 * of which frame timestamps are represented. For fixed-fps content, | |
2843
ea05470188e4
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
2838
diff
changeset
|
1095 * timebase should be 1/framerate and timestamp increments should be |
ea05470188e4
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
2838
diff
changeset
|
1096 * identically 1. |
4794 | 1097 * - encoding: MUST be set by user. |
1098 * - decoding: Set by libavcodec. | |
684 | 1099 */ |
2637 | 1100 AVRational time_base; |
2967 | 1101 |
2843
ea05470188e4
time_base description by Rich Felker | dalias, aerifal cx
michael
parents:
2838
diff
changeset
|
1102 /* video only */ |
1126
77ccf7fe3bd0
per context frame_rate_base, this should finally fix frame_rate related av sync issues
michaelni
parents:
1118
diff
changeset
|
1103 /** |
2270 | 1104 * picture width / height. |
2967 | 1105 * - encoding: MUST be set by user. |
4794 | 1106 * - decoding: Set by libavcodec. |
1107 * Note: For compatibility it is possible to set this instead of | |
1108 * coded_width/height before decoding. | |
684 | 1109 */ |
0 | 1110 int width, height; |
2967 | 1111 |
618 | 1112 #define FF_ASPECT_EXTENDED 15 |
684 | 1113 |
1114 /** | |
4794 | 1115 * the number of pictures in a group of pictures, or 0 for intra_only |
1116 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1117 * - decoding: unused |
684 | 1118 */ |
1119 int gop_size; | |
1120 | |
1121 /** | |
4794 | 1122 * Pixel format, see PIX_FMT_xxx. |
1123 * - encoding: Set by user. | |
1124 * - decoding: Set by libavcodec. | |
684 | 1125 */ |
1422
efeed6e29f9b
oooooops, having 2 Eterms open and doing cvs diff in one and cvs commit in the other sucks, especially if they are in different directories (MPlayer/main/libavcodec vs. ffmpeg/libavcodec)
michaelni
parents:
1421
diff
changeset
|
1126 enum PixelFormat pix_fmt; |
2967 | 1127 |
1113
bbcb4fda2b86
Frame rate emulation patch by (Max Krasnyansky <maxk at qualcomm dot com>)
michaelni
parents:
1112
diff
changeset
|
1128 /** |
4794 | 1129 * Frame rate emulation. If not zero, the lower layer (i.e. format handler) |
1113
bbcb4fda2b86
Frame rate emulation patch by (Max Krasnyansky <maxk at qualcomm dot com>)
michaelni
parents:
1112
diff
changeset
|
1130 * has to read frames at native frame rate. |
4794 | 1131 * - encoding: Set by user. |
1132 * - decoding: unused | |
1113
bbcb4fda2b86
Frame rate emulation patch by (Max Krasnyansky <maxk at qualcomm dot com>)
michaelni
parents:
1112
diff
changeset
|
1133 */ |
bbcb4fda2b86
Frame rate emulation patch by (Max Krasnyansky <maxk at qualcomm dot com>)
michaelni
parents:
1112
diff
changeset
|
1134 int rate_emu; |
2967 | 1135 |
684 | 1136 /** |
4794 | 1137 * If non NULL, 'draw_horiz_band' is called by the libavcodec |
1138 * decoder to draw a horizontal band. It improves cache usage. Not | |
684 | 1139 * all codecs can do that. You must check the codec capabilities |
4794 | 1140 * beforehand. |
8890 | 1141 * The function is also used by hardware acceleration APIs. |
1142 * It is called at least once during frame decoding to pass | |
1143 * the data needed for hardware render. | |
1144 * In that mode instead of pixel data, AVFrame points to | |
1145 * a structure specific to the acceleration API. The application | |
1146 * reads the structure and can change some fields to indicate progress | |
1147 * or mark state. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1148 * - encoding: unused |
4794 | 1149 * - decoding: Set by user. |
1370 | 1150 * @param height the height of the slice |
1151 * @param y the y position of the slice | |
1152 * @param type 1->top field, 2->bottom field, 3->frame | |
1153 * @param offset offset into the AVFrame.data from which the slice should be read | |
684 | 1154 */ |
67 | 1155 void (*draw_horiz_band)(struct AVCodecContext *s, |
1488
766a2f4edbea
avcodec const correctness patch by (Drew Hess <dhess at ilm dot com>)
michaelni
parents:
1486
diff
changeset
|
1156 const AVFrame *src, int offset[4], |
1370 | 1157 int y, int type, int height); |
67 | 1158 |
0 | 1159 /* audio only */ |
4794 | 1160 int sample_rate; ///< samples per second |
6776 | 1161 int channels; ///< number of audio channels |
2479 | 1162 |
1163 /** | |
4794 | 1164 * audio sample format |
1165 * - encoding: Set by user. | |
1166 * - decoding: Set by libavcodec. | |
2479 | 1167 */ |
9882
7b58b1410f48
Make documentation better match the code. Now AVCodecContext.sample_fmt
vitor
parents:
9866
diff
changeset
|
1168 enum SampleFormat sample_fmt; ///< sample format |
0 | 1169 |
4794 | 1170 /* The following data should not be initialized. */ |
2768
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1171 /** |
4794 | 1172 * Samples per packet, initialized when calling 'init'. |
2768
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1173 */ |
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1174 int frame_size; |
2967 | 1175 int frame_number; ///< audio or video frame number |
9722
0bfb23c7633d
remove apparently unused real_pict_num from AVCodecContext
bcoudurier
parents:
9628
diff
changeset
|
1176 #if LIBAVCODEC_VERSION_MAJOR < 53 |
4794 | 1177 int real_pict_num; ///< Returns the real picture number of previous encoded frame. |
9722
0bfb23c7633d
remove apparently unused real_pict_num from AVCodecContext
bcoudurier
parents:
9628
diff
changeset
|
1178 #endif |
2967 | 1179 |
684 | 1180 /** |
4794 | 1181 * Number of frames the decoded output will be delayed relative to |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1182 * the encoded input. |
4794 | 1183 * - encoding: Set by libavcodec. |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1184 * - decoding: unused |
684 | 1185 */ |
1186 int delay; | |
2967 | 1187 |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1188 /* - encoding parameters */ |
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1189 float qcompress; ///< amount of qscale change between easy & hard scenes (0.0-1.0) |
2967 | 1190 float qblur; ///< amount of qscale smoothing over time (0.0-1.0) |
1191 | |
684 | 1192 /** |
4794 | 1193 * minimum quantizer |
1194 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1195 * - decoding: unused |
684 | 1196 */ |
1197 int qmin; | |
1198 | |
1199 /** | |
4794 | 1200 * maximum quantizer |
1201 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1202 * - decoding: unused |
684 | 1203 */ |
1204 int qmax; | |
1205 | |
1206 /** | |
4794 | 1207 * maximum quantizer difference between frames |
1208 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1209 * - decoding: unused |
684 | 1210 */ |
1211 int max_qdiff; | |
1212 | |
1213 /** | |
4794 | 1214 * maximum number of B-frames between non-B-frames |
1215 * Note: The output will be delayed by max_b_frames+1 relative to the input. | |
1216 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1217 * - decoding: unused |
684 | 1218 */ |
1219 int max_b_frames; | |
1220 | |
1221 /** | |
4794 | 1222 * qscale factor between IP and B-frames |
7342
8c4e0043c068
Correct b_quant offset comment in avcodec.h, it is the description for
diego
parents:
7324
diff
changeset
|
1223 * If > 0 then the last P-frame quantizer will be used (q= lastp_q*factor+offset). |
8c4e0043c068
Correct b_quant offset comment in avcodec.h, it is the description for
diego
parents:
7324
diff
changeset
|
1224 * If < 0 then normal ratecontrol will be done (q= -normal_q*factor+offset). |
4794 | 1225 * - encoding: Set by user. |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1226 * - decoding: unused |
684 | 1227 */ |
1228 float b_quant_factor; | |
2967 | 1229 |
684 | 1230 /** obsolete FIXME remove */ |
1231 int rc_strategy; | |
3064 | 1232 #define FF_RC_STRATEGY_XVID 1 |
1233 | |
329 | 1234 int b_frame_strategy; |
324 | 1235 |
684 | 1236 /** |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
1237 * hurry up amount |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
1238 * - encoding: unused |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
1239 * - decoding: Set by user. 1-> Skip B-frames, 2-> Skip IDCT/dequant too, 5-> Skip everything except header |
4566 | 1240 * @deprecated Deprecated in favor of skip_idct and skip_frame. |
684 | 1241 */ |
1242 int hurry_up; | |
2967 | 1243 |
0 | 1244 struct AVCodec *codec; |
2967 | 1245 |
0 | 1246 void *priv_data; |
1247 | |
2764 | 1248 int rtp_payload_size; /* The size of the RTP payload: the coder will */ |
4794 | 1249 /* do its best to deliver a chunk with size */ |
162 | 1250 /* below rtp_payload_size, the chunk will start */ |
4794 | 1251 /* with a start code on some codecs like H.263. */ |
162 | 1252 /* This doesn't take account of any particular */ |
4794 | 1253 /* headers inside the transmitted RTP payload. */ |
231 | 1254 |
2967 | 1255 |
4794 | 1256 /* The RTP callback: This function is called */ |
1257 /* every time the encoder has a packet to send. */ | |
1258 /* It depends on the encoder if the data starts */ | |
1259 /* with a Start Code (it should). H.263 does. */ | |
1260 /* mb_nb contains the number of macroblocks */ | |
1261 /* encoded in the RTP payload. */ | |
2967 | 1262 void (*rtp_callback)(struct AVCodecContext *avctx, void *data, int size, int mb_nb); |
231 | 1263 |
286 | 1264 /* statistics, used for 2-pass encoding */ |
1265 int mv_bits; | |
1266 int header_bits; | |
1267 int i_tex_bits; | |
1268 int p_tex_bits; | |
1269 int i_count; | |
1270 int p_count; | |
1271 int skip_count; | |
684 | 1272 int misc_bits; |
2967 | 1273 |
684 | 1274 /** |
4794 | 1275 * number of bits used for the previously encoded frame |
1276 * - encoding: Set by libavcodec. | |
1116 | 1277 * - decoding: unused |
684 | 1278 */ |
286 | 1279 int frame_bits; |
1116 | 1280 |
684 | 1281 /** |
4794 | 1282 * Private data of the user, can be used to carry app specific stuff. |
1283 * - encoding: Set by user. | |
1284 * - decoding: Set by user. | |
684 | 1285 */ |
1286 void *opaque; | |
1287 | |
0 | 1288 char codec_name[32]; |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
1289 enum AVMediaType codec_type; /* see AVMEDIA_TYPE_xxx */ |
371
8187bb132d85
* Start using enumerated types (makes debugging much easier)
philipjsg
parents:
367
diff
changeset
|
1290 enum CodecID codec_id; /* see CODEC_ID_xxx */ |
2967 | 1291 |
1116 | 1292 /** |
1293 * fourcc (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A'). | |
4794 | 1294 * This is used to work around some encoder bugs. |
1295 * A demuxer should set this to what is stored in the field used to identify the codec. | |
1296 * If there are multiple such fields in a container then the demuxer should choose the one | |
1297 * which maximizes the information about the used codec. | |
1298 * If the codec tag field in a container is larger then 32 bits then the demuxer should | |
1299 * remap the longer ID to 32 bits with a table or other structure. Alternatively a new | |
4711 | 1300 * extra_codec_tag + size could be added but for this a clear advantage must be demonstrated |
4794 | 1301 * first. |
1302 * - encoding: Set by user, if not then the default based on codec_id will be used. | |
1303 * - decoding: Set by user, will be converted to uppercase by libavcodec during init. | |
1116 | 1304 */ |
1305 unsigned int codec_tag; | |
2967 | 1306 |
684 | 1307 /** |
4794 | 1308 * Work around bugs in encoders which sometimes cannot be detected automatically. |
1309 * - encoding: Set by user | |
1310 * - decoding: Set by user | |
684 | 1311 */ |
1312 int workaround_bugs; | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1313 #define FF_BUG_AUTODETECT 1 ///< autodetection |
745
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1314 #define FF_BUG_OLD_MSMPEG4 2 |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1315 #define FF_BUG_XVID_ILACE 4 |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1316 #define FF_BUG_UMP4 8 |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1317 #define FF_BUG_NO_PADDING 16 |
1997 | 1318 #define FF_BUG_AMV 32 |
4794 | 1319 #define FF_BUG_AC_VLC 0 ///< Will be removed, libavcodec can now handle these non-compliant files by default. |
760 | 1320 #define FF_BUG_QPEL_CHROMA 64 |
984 | 1321 #define FF_BUG_STD_QPEL 128 |
1048 | 1322 #define FF_BUG_QPEL_CHROMA2 256 |
1053
f07fd48c23d4
direct blocksize in bframes fix (might fix qpel+bframe bug)
michaelni
parents:
1048
diff
changeset
|
1323 #define FF_BUG_DIRECT_BLOCKSIZE 512 |
1137 | 1324 #define FF_BUG_EDGE 1024 |
1916 | 1325 #define FF_BUG_HPEL_CHROMA 2048 |
2004 | 1326 #define FF_BUG_DC_CLIP 4096 |
4794 | 1327 #define FF_BUG_MS 8192 ///< Work around various bugs in Microsoft's broken decoders. |
11125
1f13ac0e696b
Try to support truncated h264 frames mixed with mpeg pes headers in mkv.
michael
parents:
11123
diff
changeset
|
1328 #define FF_BUG_TRUNCATED 16384 |
4794 | 1329 //#define FF_BUG_FAKE_SCALABILITY 16 //Autodetection should work 100%. |
2967 | 1330 |
684 | 1331 /** |
4794 | 1332 * luma single coefficient elimination threshold |
1333 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1334 * - decoding: unused |
684 | 1335 */ |
460 | 1336 int luma_elim_threshold; |
2967 | 1337 |
684 | 1338 /** |
4794 | 1339 * chroma single coeff elimination threshold |
1340 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1341 * - decoding: unused |
684 | 1342 */ |
460 | 1343 int chroma_elim_threshold; |
2967 | 1344 |
684 | 1345 /** |
4794 | 1346 * strictly follow the standard (MPEG4, ...). |
1347 * - encoding: Set by user. | |
7324 | 1348 * - decoding: Set by user. |
1349 * Setting this to STRICT or higher means the encoder and decoder will | |
1350 * generally do stupid things. While setting it to inofficial or lower | |
1351 * will mean the encoder might use things that are not supported by all | |
1352 * spec compliant decoders. Decoders make no difference between normal, | |
1353 * inofficial and experimental, that is they always try to decode things | |
1354 * when they can unless they are explicitly asked to behave stupid | |
1355 * (=strictly conform to the specs) | |
684 | 1356 */ |
1357 int strict_std_compliance; | |
4794 | 1358 #define FF_COMPLIANCE_VERY_STRICT 2 ///< Strictly conform to a older more strict version of the spec or reference software. |
1359 #define FF_COMPLIANCE_STRICT 1 ///< Strictly conform to all the things in the spec no matter what consequences. | |
2658
d1609cfeb1d0
#defines for strict_std_compliance and split between inofficial extensions and non standarized things
michael
parents:
2637
diff
changeset
|
1360 #define FF_COMPLIANCE_NORMAL 0 |
4794 | 1361 #define FF_COMPLIANCE_INOFFICIAL -1 ///< Allow inofficial extensions. |
1362 #define FF_COMPLIANCE_EXPERIMENTAL -2 ///< Allow nonstandardized experimental things. | |
2658
d1609cfeb1d0
#defines for strict_std_compliance and split between inofficial extensions and non standarized things
michael
parents:
2637
diff
changeset
|
1363 |
684 | 1364 /** |
4794 | 1365 * qscale offset between IP and B-frames |
1366 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1367 * - decoding: unused |
684 | 1368 */ |
1369 float b_quant_offset; | |
2967 | 1370 |
684 | 1371 /** |
7831 | 1372 * Error recognization; higher values will detect more errors but may |
4794 | 1373 * misdetect some more or less valid parts as errors. |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1374 * - encoding: unused |
4794 | 1375 * - decoding: Set by user. |
684 | 1376 */ |
7831 | 1377 int error_recognition; |
2879 | 1378 #define FF_ER_CAREFUL 1 |
905
2b93dc762f9a
fixing illegal 3. esc bug (the mpeg4 std only requires encoders to use unescaped symbols but not esc1 or esc2 if they are shorter than esc3, andjust beause its logical to use the shortest possible vlc doesnt mean encoders do that)
michaelni
parents:
903
diff
changeset
|
1379 #define FF_ER_COMPLIANT 2 |
2b93dc762f9a
fixing illegal 3. esc bug (the mpeg4 std only requires encoders to use unescaped symbols but not esc1 or esc2 if they are shorter than esc3, andjust beause its logical to use the shortest possible vlc doesnt mean encoders do that)
michaelni
parents:
903
diff
changeset
|
1380 #define FF_ER_AGGRESSIVE 3 |
2b93dc762f9a
fixing illegal 3. esc bug (the mpeg4 std only requires encoders to use unescaped symbols but not esc1 or esc2 if they are shorter than esc3, andjust beause its logical to use the shortest possible vlc doesnt mean encoders do that)
michaelni
parents:
903
diff
changeset
|
1381 #define FF_ER_VERY_AGGRESSIVE 4 |
2967 | 1382 |
803
08423289ec57
exporting the internal qscale table, this allso fixes the ordering
michaelni
parents:
783
diff
changeset
|
1383 /** |
4794 | 1384 * Called at the beginning of each frame to get a buffer for it. |
1385 * If pic.reference is set then the frame will be read later by libavcodec. | |
11311
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
1386 * avcodec_align_dimensions2() should be used to find the required width and |
4794 | 1387 * height, as they normally need to be rounded up to the next multiple of 16. |
9827
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
1388 * if CODEC_CAP_DR1 is not set then get_buffer() must call |
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
1389 * avcodec_default_get_buffer() instead of providing buffers allocated by |
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
1390 * some other means. |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1391 * - encoding: unused |
4794 | 1392 * - decoding: Set by libavcodec., user can override. |
803
08423289ec57
exporting the internal qscale table, this allso fixes the ordering
michaelni
parents:
783
diff
changeset
|
1393 */ |
925 | 1394 int (*get_buffer)(struct AVCodecContext *c, AVFrame *pic); |
2967 | 1395 |
684 | 1396 /** |
6495 | 1397 * Called to release buffers which were allocated with get_buffer. |
4794 | 1398 * A released buffer can be reused in get_buffer(). |
1399 * pic.data[*] must be set to NULL. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1400 * - encoding: unused |
4794 | 1401 * - decoding: Set by libavcodec., user can override. |
684 | 1402 */ |
925 | 1403 void (*release_buffer)(struct AVCodecContext *c, AVFrame *pic); |
556 | 1404 |
684 | 1405 /** |
8761 | 1406 * Size of the frame reordering buffer in the decoder. |
8883
62342da1ec78
Attempt to clarify draw_horiz_band description and fix two random typos.
diego
parents:
8882
diff
changeset
|
1407 * For MPEG-2 it is 1 IPB or 0 low delay IP. |
4794 | 1408 * - encoding: Set by libavcodec. |
1409 * - decoding: Set by libavcodec. | |
684 | 1410 */ |
1411 int has_b_frames; | |
2768
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1412 |
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1413 /** |
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1414 * number of bytes per packet if constant and known or 0 |
4794 | 1415 * Used by some WAV based audio codecs. |
2768
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1416 */ |
d2b3f948599d
tiny docs improvement which i apparebtly forgot to commit
michael
parents:
2764
diff
changeset
|
1417 int block_align; |
2967 | 1418 |
4794 | 1419 int parse_only; /* - decoding only: If true, only parsing is done |
581
8adda0af04e2
added proposed API for parse_only mode to extract compressed frames from compressed streams
bellard
parents:
573
diff
changeset
|
1420 (function avcodec_parse_frame()). The frame |
8adda0af04e2
added proposed API for parse_only mode to extract compressed frames from compressed streams
bellard
parents:
573
diff
changeset
|
1421 data is returned. Only MPEG codecs support this now. */ |
2967 | 1422 |
684 | 1423 /** |
4794 | 1424 * 0-> h263 quant 1-> mpeg quant |
1425 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1426 * - decoding: unused |
684 | 1427 */ |
1428 int mpeg_quant; | |
2967 | 1429 |
684 | 1430 /** |
4794 | 1431 * pass1 encoding statistics output buffer |
1432 * - encoding: Set by libavcodec. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1433 * - decoding: unused |
684 | 1434 */ |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1435 char *stats_out; |
2967 | 1436 |
684 | 1437 /** |
4794 | 1438 * pass2 encoding statistics input buffer |
1439 * Concatenated stuff from stats_out of pass1 should be placed here. | |
1440 * - encoding: Allocated/set/freed by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1441 * - decoding: unused |
684 | 1442 */ |
1443 char *stats_in; | |
2967 | 1444 |
684 | 1445 /** |
4794 | 1446 * ratecontrol qmin qmax limiting method |
1447 * 0-> clipping, 1-> use a nice continous function to limit qscale wthin qmin/qmax. | |
1448 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1449 * - decoding: unused |
684 | 1450 */ |
613 | 1451 float rc_qsquish; |
684 | 1452 |
613 | 1453 float rc_qmod_amp; |
1454 int rc_qmod_freq; | |
2967 | 1455 |
684 | 1456 /** |
4794 | 1457 * ratecontrol override, see RcOverride |
1458 * - encoding: Allocated/set/freed by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1459 * - decoding: unused |
684 | 1460 */ |
613 | 1461 RcOverride *rc_override; |
1462 int rc_override_count; | |
2967 | 1463 |
684 | 1464 /** |
4794 | 1465 * rate control equation |
1466 * - encoding: Set by user | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1467 * - decoding: unused |
684 | 1468 */ |
6354 | 1469 const char *rc_eq; |
2967 | 1470 |
684 | 1471 /** |
4794 | 1472 * maximum bitrate |
1473 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1474 * - decoding: unused |
684 | 1475 */ |
613 | 1476 int rc_max_rate; |
2967 | 1477 |
684 | 1478 /** |
4794 | 1479 * minimum bitrate |
1480 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1481 * - decoding: unused |
684 | 1482 */ |
613 | 1483 int rc_min_rate; |
2967 | 1484 |
684 | 1485 /** |
4794 | 1486 * decoder bitstream buffer size |
1487 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1488 * - decoding: unused |
684 | 1489 */ |
613 | 1490 int rc_buffer_size; |
1491 float rc_buffer_aggressivity; | |
684 | 1492 |
1493 /** | |
4794 | 1494 * qscale factor between P and I-frames |
1495 * If > 0 then the last p frame quantizer will be used (q= lastp_q*factor+offset). | |
1496 * If < 0 then normal ratecontrol will be done (q= -normal_q*factor+offset). | |
1497 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1498 * - decoding: unused |
684 | 1499 */ |
1500 float i_quant_factor; | |
2967 | 1501 |
684 | 1502 /** |
4794 | 1503 * qscale offset between P and I-frames |
1504 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1505 * - decoding: unused |
684 | 1506 */ |
1507 float i_quant_offset; | |
2967 | 1508 |
684 | 1509 /** |
4794 | 1510 * initial complexity for pass1 ratecontrol |
1511 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1512 * - decoding: unused |
684 | 1513 */ |
613 | 1514 float rc_initial_cplx; |
581
8adda0af04e2
added proposed API for parse_only mode to extract compressed frames from compressed streams
bellard
parents:
573
diff
changeset
|
1515 |
684 | 1516 /** |
4794 | 1517 * DCT algorithm, see FF_DCT_* below |
1518 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1519 * - decoding: unused |
684 | 1520 */ |
625
bb6a69f9d409
slow but accurate integer dct from IJG (should be ok with the LGPL as the old DCT is the fast integer DCT from IJG)
michaelni
parents:
618
diff
changeset
|
1521 int dct_algo; |
628
f596db4aa871
sun solaris compilation bugfix, patch by (Martin Olschewski <olschewski at zpr dot uni-koeln dot de>)
michaelni
parents:
625
diff
changeset
|
1522 #define FF_DCT_AUTO 0 |
625
bb6a69f9d409
slow but accurate integer dct from IJG (should be ok with the LGPL as the old DCT is the fast integer DCT from IJG)
michaelni
parents:
618
diff
changeset
|
1523 #define FF_DCT_FASTINT 1 |
628
f596db4aa871
sun solaris compilation bugfix, patch by (Martin Olschewski <olschewski at zpr dot uni-koeln dot de>)
michaelni
parents:
625
diff
changeset
|
1524 #define FF_DCT_INT 2 |
f596db4aa871
sun solaris compilation bugfix, patch by (Martin Olschewski <olschewski at zpr dot uni-koeln dot de>)
michaelni
parents:
625
diff
changeset
|
1525 #define FF_DCT_MMX 3 |
f596db4aa871
sun solaris compilation bugfix, patch by (Martin Olschewski <olschewski at zpr dot uni-koeln dot de>)
michaelni
parents:
625
diff
changeset
|
1526 #define FF_DCT_MLIB 4 |
828
ace3ccd18dd2
Altivec Patch (Mark III) by (Dieter Shirley <dieters at schemasoft dot com>)
michaelni
parents:
827
diff
changeset
|
1527 #define FF_DCT_ALTIVEC 5 |
1557 | 1528 #define FF_DCT_FAAN 6 |
2967 | 1529 |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1530 /** |
4794 | 1531 * luminance masking (0-> disabled) |
1532 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1533 * - decoding: unused |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1534 */ |
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1535 float lumi_masking; |
2967 | 1536 |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1537 /** |
4794 | 1538 * temporary complexity masking (0-> disabled) |
1539 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1540 * - decoding: unused |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1541 */ |
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1542 float temporal_cplx_masking; |
2967 | 1543 |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1544 /** |
4794 | 1545 * spatial complexity masking (0-> disabled) |
1546 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1547 * - decoding: unused |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1548 */ |
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1549 float spatial_cplx_masking; |
2967 | 1550 |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1551 /** |
4794 | 1552 * p block masking (0-> disabled) |
1553 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1554 * - decoding: unused |
690
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1555 */ |
a1c69cb685b3
adaptive quantization (lumi/temporal & spatial complexity masking)
michaelni
parents:
686
diff
changeset
|
1556 float p_masking; |
654 | 1557 |
693
b6a7ff92df57
darkness masking (lumi masking does only bright stuff now)
michaelni
parents:
690
diff
changeset
|
1558 /** |
4794 | 1559 * darkness masking (0-> disabled) |
1560 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1561 * - decoding: unused |
693
b6a7ff92df57
darkness masking (lumi masking does only bright stuff now)
michaelni
parents:
690
diff
changeset
|
1562 */ |
b6a7ff92df57
darkness masking (lumi masking does only bright stuff now)
michaelni
parents:
690
diff
changeset
|
1563 float dark_masking; |
2967 | 1564 |
700
0fb4c66527e1
autodetect UMP4 (by adding a fourcc field to AVCodecContext)
michaelni
parents:
697
diff
changeset
|
1565 /** |
4794 | 1566 * IDCT algorithm, see FF_IDCT_* below. |
1567 * - encoding: Set by user. | |
1568 * - decoding: Set by user. | |
706
e65798d228ea
idct permutation cleanup, idct can be selected per context now
michaelni
parents:
703
diff
changeset
|
1569 */ |
e65798d228ea
idct permutation cleanup, idct can be selected per context now
michaelni
parents:
703
diff
changeset
|
1570 int idct_algo; |
5590 | 1571 #define FF_IDCT_AUTO 0 |
1572 #define FF_IDCT_INT 1 | |
1573 #define FF_IDCT_SIMPLE 2 | |
1574 #define FF_IDCT_SIMPLEMMX 3 | |
1575 #define FF_IDCT_LIBMPEG2MMX 4 | |
1576 #define FF_IDCT_PS2 5 | |
1577 #define FF_IDCT_MLIB 6 | |
1578 #define FF_IDCT_ARM 7 | |
1579 #define FF_IDCT_ALTIVEC 8 | |
1580 #define FF_IDCT_SH4 9 | |
1581 #define FF_IDCT_SIMPLEARM 10 | |
1582 #define FF_IDCT_H264 11 | |
1583 #define FF_IDCT_VP3 12 | |
1584 #define FF_IDCT_IPP 13 | |
1585 #define FF_IDCT_XVIDMMX 14 | |
1586 #define FF_IDCT_CAVS 15 | |
3769 | 1587 #define FF_IDCT_SIMPLEARMV5TE 16 |
5590 | 1588 #define FF_IDCT_SIMPLEARMV6 17 |
5618 | 1589 #define FF_IDCT_SIMPLEVIS 18 |
5887 | 1590 #define FF_IDCT_WMV2 19 |
6407 | 1591 #define FF_IDCT_FAAN 20 |
8119 | 1592 #define FF_IDCT_EA 21 |
8335 | 1593 #define FF_IDCT_SIMPLENEON 22 |
8619 | 1594 #define FF_IDCT_SIMPLEALPHA 23 |
11231 | 1595 #define FF_IDCT_BINK 24 |
706
e65798d228ea
idct permutation cleanup, idct can be selected per context now
michaelni
parents:
703
diff
changeset
|
1596 |
713
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1597 /** |
4794 | 1598 * slice count |
1599 * - encoding: Set by libavcodec. | |
1600 * - decoding: Set by user (or 0). | |
713
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1601 */ |
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1602 int slice_count; |
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1603 /** |
4794 | 1604 * slice offsets in the frame in bytes |
1605 * - encoding: Set/allocated by libavcodec. | |
1606 * - decoding: Set/allocated by user (or NULL). | |
713
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1607 */ |
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1608 int *slice_offset; |
e74a563eb643
rv10 cleanup (de)muxer still needs to be cleaned up (still searching volunteer for that ;) )
michaelni
parents:
706
diff
changeset
|
1609 |
745
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1610 /** |
4794 | 1611 * error concealment flags |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1612 * - encoding: unused |
4794 | 1613 * - decoding: Set by user. |
745
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1614 */ |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1615 int error_concealment; |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1616 #define FF_EC_GUESS_MVS 1 |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1617 #define FF_EC_DEBLOCK 2 |
25d7fb7c89be
better/cleaner error resilience (done in a 2nd pass after decoding)
michaelni
parents:
733
diff
changeset
|
1618 |
803
08423289ec57
exporting the internal qscale table, this allso fixes the ordering
michaelni
parents:
783
diff
changeset
|
1619 /** |
1114 | 1620 * dsp_mask could be add used to disable unwanted CPU features |
849 | 1621 * CPU features (i.e. MMX, SSE. ...) |
1114 | 1622 * |
4794 | 1623 * With the FORCE flag you may instead enable given CPU features. |
1624 * (Dangerous: Usable in case of misdetection, improper usage however will | |
1625 * result into program crash.) | |
849 | 1626 */ |
1114 | 1627 unsigned dsp_mask; |
4794 | 1628 #define FF_MM_FORCE 0x80000000 /* Force usage of selected flags (OR) */ |
1114 | 1629 /* lower 16 bits - CPU features */ |
6044 | 1630 #define FF_MM_MMX 0x0001 ///< standard MMX |
1631 #define FF_MM_3DNOW 0x0004 ///< AMD 3DNOW | |
9342
7f594601d5e9
Rename FF_MM_MMXEXT to FF_MM_MMX2, for both clarity and consistency
stefano
parents:
9336
diff
changeset
|
1632 #if LIBAVCODEC_VERSION_MAJOR < 53 |
6044 | 1633 #define FF_MM_MMXEXT 0x0002 ///< SSE integer functions or AMD MMX ext |
9342
7f594601d5e9
Rename FF_MM_MMXEXT to FF_MM_MMX2, for both clarity and consistency
stefano
parents:
9336
diff
changeset
|
1634 #endif |
7f594601d5e9
Rename FF_MM_MMXEXT to FF_MM_MMX2, for both clarity and consistency
stefano
parents:
9336
diff
changeset
|
1635 #define FF_MM_MMX2 0x0002 ///< SSE integer functions or AMD MMX ext |
6044 | 1636 #define FF_MM_SSE 0x0008 ///< SSE functions |
1637 #define FF_MM_SSE2 0x0010 ///< PIV SSE2 functions | |
1638 #define FF_MM_3DNOWEXT 0x0020 ///< AMD 3DNowExt | |
1639 #define FF_MM_SSE3 0x0040 ///< Prescott SSE3 functions | |
1640 #define FF_MM_SSSE3 0x0080 ///< Conroe SSSE3 functions | |
9329 | 1641 #define FF_MM_SSE4 0x0100 ///< Penryn SSE4.1 functions |
1642 #define FF_MM_SSE42 0x0200 ///< Nehalem SSE4.2 functions | |
6044 | 1643 #define FF_MM_IWMMXT 0x0100 ///< XScale IWMMXT |
8104
0d108ec85620
Remove duplicated MM_* macros for CPU capabilities from dsputil.h.
rathann
parents:
8102
diff
changeset
|
1644 #define FF_MM_ALTIVEC 0x0001 ///< standard AltiVec |
866 | 1645 |
1646 /** | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1647 * bits per sample/pixel from the demuxer (needed for huffyuv). |
4794 | 1648 * - encoding: Set by libavcodec. |
1649 * - decoding: Set by user. | |
866 | 1650 */ |
7720
b1cacb2f48a0
Change AVCodecContext.bits_per_sample to bits_per_coded_sample.
pross
parents:
7632
diff
changeset
|
1651 int bits_per_coded_sample; |
2967 | 1652 |
866 | 1653 /** |
4794 | 1654 * prediction method (needed for huffyuv) |
1655 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1656 * - decoding: unused |
866 | 1657 */ |
1658 int prediction_method; | |
1659 #define FF_PRED_LEFT 0 | |
1660 #define FF_PRED_PLANE 1 | |
1661 #define FF_PRED_MEDIAN 2 | |
2967 | 1662 |
880 | 1663 /** |
4794 | 1664 * sample aspect ratio (0 if unknown) |
7786 | 1665 * That is the width of a pixel divided by the height of the pixel. |
4794 | 1666 * Numerator and denominator must be relatively prime and smaller than 256 for some video standards. |
1667 * - encoding: Set by user. | |
1668 * - decoding: Set by libavcodec. | |
880 | 1669 */ |
1548 | 1670 AVRational sample_aspect_ratio; |
903 | 1671 |
1672 /** | |
4794 | 1673 * the picture in the bitstream |
1674 * - encoding: Set by libavcodec. | |
1675 * - decoding: Set by libavcodec. | |
903 | 1676 */ |
925 | 1677 AVFrame *coded_frame; |
906 | 1678 |
1679 /** | |
4794 | 1680 * debug |
1681 * - encoding: Set by user. | |
1682 * - decoding: Set by user. | |
906 | 1683 */ |
1684 int debug; | |
5590 | 1685 #define FF_DEBUG_PICT_INFO 1 |
1686 #define FF_DEBUG_RC 2 | |
1687 #define FF_DEBUG_BITSTREAM 4 | |
1688 #define FF_DEBUG_MB_TYPE 8 | |
1689 #define FF_DEBUG_QP 16 | |
1690 #define FF_DEBUG_MV 32 | |
1691 #define FF_DEBUG_DCT_COEFF 0x00000040 | |
1692 #define FF_DEBUG_SKIP 0x00000080 | |
1693 #define FF_DEBUG_STARTCODE 0x00000100 | |
1694 #define FF_DEBUG_PTS 0x00000200 | |
1695 #define FF_DEBUG_ER 0x00000400 | |
1696 #define FF_DEBUG_MMCO 0x00000800 | |
1697 #define FF_DEBUG_BUGS 0x00001000 | |
1698 #define FF_DEBUG_VIS_QP 0x00002000 | |
1685 | 1699 #define FF_DEBUG_VIS_MB_TYPE 0x00004000 |
7406
7b2819083061
Add a new -debug option for tracing calls to the default get/release_buffer functions.
astrange
parents:
7342
diff
changeset
|
1700 #define FF_DEBUG_BUFFERS 0x00008000 |
2967 | 1701 |
909
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
1702 /** |
4794 | 1703 * debug |
1704 * - encoding: Set by user. | |
1705 * - decoding: Set by user. | |
1706
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1706 */ |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1707 int debug_mv; |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1708 #define FF_DEBUG_VIS_MV_P_FOR 0x00000001 //visualize forward predicted MVs of P frames |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1709 #define FF_DEBUG_VIS_MV_B_FOR 0x00000002 //visualize forward predicted MVs of B frames |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1710 #define FF_DEBUG_VIS_MV_B_BACK 0x00000004 //visualize backward predicted MVs of B frames |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1711 |
3ba5c493db6f
motion vector vissualization improvements patch by (Wolfgang Hesseler <qv at multimediaware dot com>)
michael
parents:
1696
diff
changeset
|
1712 /** |
4794 | 1713 * error |
1714 * - encoding: Set by libavcodec if flags&CODEC_FLAG_PSNR. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1715 * - decoding: unused |
909
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
1716 */ |
8ae1e4c24e91
new PSNR code (now works with chroma, b frames, ...)
michaelni
parents:
906
diff
changeset
|
1717 uint64_t error[4]; |
2967 | 1718 |
932 | 1719 /** |
4794 | 1720 * minimum MB quantizer |
2494
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
1721 * - encoding: unused |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1722 * - decoding: unused |
932 | 1723 */ |
1724 int mb_qmin; | |
1725 | |
1726 /** | |
4794 | 1727 * maximum MB quantizer |
2494
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
1728 * - encoding: unused |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1729 * - decoding: unused |
932 | 1730 */ |
1731 int mb_qmax; | |
2967 | 1732 |
936 | 1733 /** |
4794 | 1734 * motion estimation comparison function |
1735 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1736 * - decoding: unused |
936 | 1737 */ |
1738 int me_cmp; | |
1739 /** | |
4794 | 1740 * subpixel motion estimation comparison function |
1741 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1742 * - decoding: unused |
936 | 1743 */ |
1744 int me_sub_cmp; | |
1745 /** | |
4794 | 1746 * macroblock comparison function (not supported yet) |
1747 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1748 * - decoding: unused |
936 | 1749 */ |
1750 int mb_cmp; | |
1729 | 1751 /** |
4794 | 1752 * interlaced DCT comparison function |
1753 * - encoding: Set by user. | |
1729 | 1754 * - decoding: unused |
1755 */ | |
1756 int ildct_cmp; | |
5590 | 1757 #define FF_CMP_SAD 0 |
1758 #define FF_CMP_SSE 1 | |
1759 #define FF_CMP_SATD 2 | |
1760 #define FF_CMP_DCT 3 | |
1761 #define FF_CMP_PSNR 4 | |
1762 #define FF_CMP_BIT 5 | |
1763 #define FF_CMP_RD 6 | |
1764 #define FF_CMP_ZERO 7 | |
1765 #define FF_CMP_VSAD 8 | |
1766 #define FF_CMP_VSSE 9 | |
1767 #define FF_CMP_NSSE 10 | |
1768 #define FF_CMP_W53 11 | |
1769 #define FF_CMP_W97 12 | |
2382 | 1770 #define FF_CMP_DCTMAX 13 |
3010
533c6386eca9
8x8 integer dct from x264 as cmp function (under CONFIG_GPL)
michael
parents:
3006
diff
changeset
|
1771 #define FF_CMP_DCT264 14 |
936 | 1772 #define FF_CMP_CHROMA 256 |
2967 | 1773 |
936 | 1774 /** |
4794 | 1775 * ME diamond size & shape |
1776 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1777 * - decoding: unused |
936 | 1778 */ |
1779 int dia_size; | |
948 | 1780 |
1781 /** | |
4794 | 1782 * amount of previous MV predictors (2a+1 x 2a+1 square) |
1783 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1784 * - decoding: unused |
948 | 1785 */ |
1786 int last_predictor_count; | |
953 | 1787 |
951 | 1788 /** |
4794 | 1789 * prepass for motion estimation |
1790 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1791 * - decoding: unused |
951 | 1792 */ |
1793 int pre_me; | |
948 | 1794 |
953 | 1795 /** |
4794 | 1796 * motion estimation prepass comparison function |
1797 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1798 * - decoding: unused |
953 | 1799 */ |
1800 int me_pre_cmp; | |
954 | 1801 |
953 | 1802 /** |
4794 | 1803 * ME prepass diamond size & shape |
1804 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1805 * - decoding: unused |
953 | 1806 */ |
1807 int pre_dia_size; | |
1808 | |
954 | 1809 /** |
4794 | 1810 * subpel ME quality |
1811 * - encoding: Set by user. | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1812 * - decoding: unused |
954 | 1813 */ |
1814 int me_subpel_quality; | |
1815 | |
998 | 1816 /** |
4794 | 1817 * callback to negotiate the pixelFormat |
998 | 1818 * @param fmt is the list of formats which are supported by the codec, |
4794 | 1819 * it is terminated by -1 as 0 is a valid format, the formats are ordered by quality. |
1820 * The first is always the native one. | |
1821 * @return the chosen format | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
1822 * - encoding: unused |
4794 | 1823 * - decoding: Set by user, if not set the native format will be chosen. |
998 | 1824 */ |
1858 | 1825 enum PixelFormat (*get_format)(struct AVCodecContext *s, const enum PixelFormat * fmt); |
1084 | 1826 |
1827 /** | |
4794 | 1828 * DTG active format information (additional aspect ratio |
1829 * information only used in DVB MPEG-2 transport streams) | |
1830 * 0 if not set. | |
2967 | 1831 * |
4794 | 1832 * - encoding: unused |
1833 * - decoding: Set by decoder. | |
1084 | 1834 */ |
1835 int dtg_active_format; | |
1836 #define FF_DTG_AFD_SAME 8 | |
1837 #define FF_DTG_AFD_4_3 9 | |
1838 #define FF_DTG_AFD_16_9 10 | |
1839 #define FF_DTG_AFD_14_9 11 | |
1840 #define FF_DTG_AFD_4_3_SP_14_9 13 | |
1841 #define FF_DTG_AFD_16_9_SP_14_9 14 | |
1842 #define FF_DTG_AFD_SP_4_3 15 | |
1843 | |
1086 | 1844 /** |
4794 | 1845 * maximum motion estimation search range in subpel units |
1846 * If 0 then no limit. | |
2967 | 1847 * |
4794 | 1848 * - encoding: Set by user. |
1849 * - decoding: unused | |
1086 | 1850 */ |
1129 | 1851 int me_range; |
1086 | 1852 |
1149 | 1853 /** |
4794 | 1854 * intra quantizer bias |
1855 * - encoding: Set by user. | |
1150 | 1856 * - decoding: unused |
1857 */ | |
1858 int intra_quant_bias; | |
1859 #define FF_DEFAULT_QUANT_BIAS 999999 | |
2967 | 1860 |
1150 | 1861 /** |
4794 | 1862 * inter quantizer bias |
1863 * - encoding: Set by user. | |
1150 | 1864 * - decoding: unused |
1865 */ | |
1866 int inter_quant_bias; | |
1210 | 1867 |
1868 /** | |
4794 | 1869 * color table ID |
1870 * - encoding: unused | |
1871 * - decoding: Which clrtable should be used for 8bit RGB images. | |
1872 * Tables have to be stored somewhere. FIXME | |
1210 | 1873 */ |
1874 int color_table_id; | |
2967 | 1875 |
1214 | 1876 /** |
4794 | 1877 * internal_buffer count |
1878 * Don't touch, used by libavcodec default_get_buffer(). | |
1214 | 1879 */ |
1880 int internal_buffer_count; | |
2967 | 1881 |
1214 | 1882 /** |
4794 | 1883 * internal_buffers |
1884 * Don't touch, used by libavcodec default_get_buffer(). | |
1214 | 1885 */ |
1886 void *internal_buffer; | |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1887 |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1888 #define FF_LAMBDA_SHIFT 7 |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1889 #define FF_LAMBDA_SCALE (1<<FF_LAMBDA_SHIFT) |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1890 #define FF_QP2LAMBDA 118 ///< factor to convert from H.263 QP to lambda |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1891 #define FF_LAMBDA_MAX (256*128-1) |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1892 |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1893 #define FF_QUALITY_SCALE FF_LAMBDA_SCALE //FIXME maybe remove |
1273 | 1894 /** |
4794 | 1895 * Global quality for codecs which cannot change it per frame. |
1896 * This should be proportional to MPEG-1/2/4 qscale. | |
1897 * - encoding: Set by user. | |
1273 | 1898 * - decoding: unused |
1899 */ | |
1900 int global_quality; | |
2967 | 1901 |
4776 | 1902 #define FF_CODER_TYPE_VLC 0 |
1903 #define FF_CODER_TYPE_AC 1 | |
4775
14e7131344b3
FF_CODER_TYPE_RAW / RLE / DEFLATE extracted from a patch by Kamil Nowosad
michael
parents:
4774
diff
changeset
|
1904 #define FF_CODER_TYPE_RAW 2 |
14e7131344b3
FF_CODER_TYPE_RAW / RLE / DEFLATE extracted from a patch by Kamil Nowosad
michael
parents:
4774
diff
changeset
|
1905 #define FF_CODER_TYPE_RLE 3 |
14e7131344b3
FF_CODER_TYPE_RAW / RLE / DEFLATE extracted from a patch by Kamil Nowosad
michael
parents:
4774
diff
changeset
|
1906 #define FF_CODER_TYPE_DEFLATE 4 |
1306 | 1907 /** |
1908 * coder type | |
4794 | 1909 * - encoding: Set by user. |
1306 | 1910 * - decoding: unused |
1911 */ | |
1912 int coder_type; | |
1913 | |
1914 /** | |
1915 * context model | |
4794 | 1916 * - encoding: Set by user. |
1306 | 1917 * - decoding: unused |
1918 */ | |
1919 int context_model; | |
2970
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1920 #if 0 |
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1921 /** |
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1922 * |
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1923 * - encoding: unused |
4794 | 1924 * - decoding: Set by user. |
2970
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1925 */ |
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1926 uint8_t * (*realloc)(struct AVCodecContext *s, uint8_t *buf, int buf_size); |
583b6ac45c07
unfinished jpeg-ls codec (feel free to finish it ...)
michael
parents:
2967
diff
changeset
|
1927 #endif |
2967 | 1928 |
1370 | 1929 /** |
1930 * slice flags | |
1931 * - encoding: unused | |
4794 | 1932 * - decoding: Set by user. |
1370 | 1933 */ |
1934 int slice_flags; | |
1935 #define SLICE_FLAG_CODED_ORDER 0x0001 ///< draw_horiz_band() is called in coded order instead of display | |
1936 #define SLICE_FLAG_ALLOW_FIELD 0x0002 ///< allow draw_horiz_band() with field slices (MPEG2 field pics) | |
1937 #define SLICE_FLAG_ALLOW_PLANE 0x0004 ///< allow draw_horiz_band() with 1 component at a time (SVQ1) | |
1938 | |
1382 | 1939 /** |
1940 * XVideo Motion Acceleration | |
1941 * - encoding: forbidden | |
1942 * - decoding: set by decoder | |
1943 */ | |
1944 int xvmc_acceleration; | |
2967 | 1945 |
1389 | 1946 /** |
1947 * macroblock decision mode | |
4794 | 1948 * - encoding: Set by user. |
1389 | 1949 * - decoding: unused |
1950 */ | |
1951 int mb_decision; | |
1952 #define FF_MB_DECISION_SIMPLE 0 ///< uses mb_cmp | |
1953 #define FF_MB_DECISION_BITS 1 ///< chooses the one which needs the fewest bits | |
6719 | 1954 #define FF_MB_DECISION_RD 2 ///< rate distortion |
1411 | 1955 |
1956 /** | |
1957 * custom intra quantization matrix | |
4794 | 1958 * - encoding: Set by user, can be NULL. |
1959 * - decoding: Set by libavcodec. | |
1411 | 1960 */ |
1961 uint16_t *intra_matrix; | |
1962 | |
1963 /** | |
1964 * custom inter quantization matrix | |
4794 | 1965 * - encoding: Set by user, can be NULL. |
1966 * - decoding: Set by libavcodec. | |
1411 | 1967 */ |
1968 uint16_t *inter_matrix; | |
2967 | 1969 |
1458
40b69d238beb
AVI stream header FCC / more reliable detection of old xvid files
michaelni
parents:
1457
diff
changeset
|
1970 /** |
40b69d238beb
AVI stream header FCC / more reliable detection of old xvid files
michaelni
parents:
1457
diff
changeset
|
1971 * fourcc from the AVI stream header (LSB first, so "ABCD" -> ('D'<<24) + ('C'<<16) + ('B'<<8) + 'A'). |
4794 | 1972 * This is used to work around some encoder bugs. |
1458
40b69d238beb
AVI stream header FCC / more reliable detection of old xvid files
michaelni
parents:
1457
diff
changeset
|
1973 * - encoding: unused |
4794 | 1974 * - decoding: Set by user, will be converted to uppercase by libavcodec during init. |
1458
40b69d238beb
AVI stream header FCC / more reliable detection of old xvid files
michaelni
parents:
1457
diff
changeset
|
1975 */ |
40b69d238beb
AVI stream header FCC / more reliable detection of old xvid files
michaelni
parents:
1457
diff
changeset
|
1976 unsigned int stream_codec_tag; |
1471 | 1977 |
1978 /** | |
4794 | 1979 * scene change detection threshold |
1980 * 0 is default, larger means fewer detected scene changes. | |
1981 * - encoding: Set by user. | |
1471 | 1982 * - decoding: unused |
1983 */ | |
1984 int scenechange_threshold; | |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1985 |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1986 /** |
4794 | 1987 * minimum Lagrange multipler |
1988 * - encoding: Set by user. | |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1989 * - decoding: unused |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1990 */ |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1991 int lmin; |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1992 |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1993 /** |
4794 | 1994 * maximum Lagrange multipler |
1995 * - encoding: Set by user. | |
1505
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1996 * - decoding: unused |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1997 */ |
010f76d07a27
use lagrange multipler instead of qp for ratecontrol, this may break some things, tell me ASAP if u notice anything broken
michaelni
parents:
1500
diff
changeset
|
1998 int lmax; |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
1999 |
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2000 /** |
4794 | 2001 * palette control structure |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2002 * - encoding: ??? (no palette-enabled encoder yet) |
4794 | 2003 * - decoding: Set by user. |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2004 */ |
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2005 struct AVPaletteControl *palctrl; |
1597 | 2006 |
2007 /** | |
2008 * noise reduction strength | |
4794 | 2009 * - encoding: Set by user. |
1597 | 2010 * - decoding: unused |
2011 */ | |
2012 int noise_reduction; | |
2967 | 2013 |
1606 | 2014 /** |
4794 | 2015 * Called at the beginning of a frame to get cr buffer for it. |
2016 * Buffer type (size, hints) must be the same. libavcodec won't check it. | |
2017 * libavcodec will pass previous buffer in pic, function should return | |
1630 | 2018 * same buffer or new buffer with old frame "painted" into it. |
4794 | 2019 * If pic.data[0] == NULL must behave like get_buffer(). |
9827
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
2020 * if CODEC_CAP_DR1 is not set then reget_buffer() must call |
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
2021 * avcodec_default_reget_buffer() instead of providing buffers allocated by |
bca8ee90e5eb
Clarify (re)get_buffer() and CODEC_CAP_DR1 relation.
michael
parents:
9825
diff
changeset
|
2022 * some other means. |
1606 | 2023 * - encoding: unused |
4794 | 2024 * - decoding: Set by libavcodec., user can override |
1606 | 2025 */ |
1630 | 2026 int (*reget_buffer)(struct AVCodecContext *c, AVFrame *pic); |
1661 | 2027 |
2028 /** | |
4794 | 2029 * Number of bits which should be loaded into the rc buffer before decoding starts. |
2030 * - encoding: Set by user. | |
1661 | 2031 * - decoding: unused |
2032 */ | |
2033 int rc_initial_buffer_occupancy; | |
2034 | |
2035 /** | |
2036 * | |
4794 | 2037 * - encoding: Set by user. |
1661 | 2038 * - decoding: unused |
2039 */ | |
2040 int inter_threshold; | |
2041 | |
2042 /** | |
4794 | 2043 * CODEC_FLAG2_* |
2044 * - encoding: Set by user. | |
2045 * - decoding: Set by user. | |
1661 | 2046 */ |
2047 int flags2; | |
1688 | 2048 |
2049 /** | |
4794 | 2050 * Simulates errors in the bitstream to test error concealment. |
2051 * - encoding: Set by user. | |
2052 * - decoding: unused | |
1688 | 2053 */ |
2054 int error_rate; | |
2967 | 2055 |
1733
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2056 /** |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2057 * MP3 antialias algorithm, see FF_AA_* below. |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2058 * - encoding: unused |
4794 | 2059 * - decoding: Set by user. |
1733
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2060 */ |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2061 int antialias_algo; |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2062 #define FF_AA_AUTO 0 |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2063 #define FF_AA_FASTINT 1 //not implemented yet |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2064 #define FF_AA_INT 2 |
b47d56b1a049
optimize compute_antialias() and add a floating point based alternative (2x faster)
michael
parents:
1729
diff
changeset
|
2065 #define FF_AA_FLOAT 3 |
1777 | 2066 /** |
4794 | 2067 * quantizer noise shaping |
2068 * - encoding: Set by user. | |
1777 | 2069 * - decoding: unused |
2070 */ | |
2071 int quantizer_noise_shaping; | |
1799 | 2072 |
2073 /** | |
4794 | 2074 * thread count |
4588
fc155ff94878
cosmetics: Fix another common typo, dependAnt --> dependEnt.
diego
parents:
4583
diff
changeset
|
2075 * is used to decide how many independent tasks should be passed to execute() |
4794 | 2076 * - encoding: Set by user. |
2077 * - decoding: Set by user. | |
1799 | 2078 */ |
2079 int thread_count; | |
2967 | 2080 |
1799 | 2081 /** |
4794 | 2082 * The codec may call this to execute several independent things. |
2083 * It will return only after finishing all tasks. | |
2084 * The user may replace this with some multithreaded implementation, | |
2085 * the default implementation will execute the parts serially. | |
1857 | 2086 * @param count the number of things to execute |
4794 | 2087 * - encoding: Set by libavcodec, user can override. |
2088 * - decoding: Set by libavcodec, user can override. | |
1799 | 2089 */ |
8129
a9734fe0811e
Making it easier to send arbitrary structures as work orders to MT workers
romansh
parents:
8119
diff
changeset
|
2090 int (*execute)(struct AVCodecContext *c, int (*func)(struct AVCodecContext *c2, void *arg), void *arg2, int *ret, int count, int size); |
2967 | 2091 |
1799 | 2092 /** |
4794 | 2093 * thread opaque |
2094 * Can be used by execute() to store some per AVCodecContext stuff. | |
1799 | 2095 * - encoding: set by execute() |
2096 * - decoding: set by execute() | |
2097 */ | |
2098 void *thread_opaque; | |
1945
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
2099 |
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
2100 /** |
4794 | 2101 * Motion estimation threshold below which no motion estimation is |
2102 * performed, but instead the user specified motion vectors are used. | |
2967 | 2103 * |
4794 | 2104 * - encoding: Set by user. |
1968
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2105 * - decoding: unused |
1945
32f68745c431
passing AVFrame instead of AVPicture around in ffmpeg, that way stuff like motion vectors can be passed from the decoder to the encoder
michael
parents:
1934
diff
changeset
|
2106 */ |
1950 | 2107 int me_threshold; |
1968
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2108 |
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2109 /** |
4794 | 2110 * Macroblock threshold below which the user specified macroblock types will be used. |
2111 * - encoding: Set by user. | |
1968
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2112 * - decoding: unused |
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2113 */ |
19c2344e800a
support reusing mb types and field select values of the source file, but use motion vectors just as additional predictors
michael
parents:
1950
diff
changeset
|
2114 int mb_threshold; |
1992 | 2115 |
2116 /** | |
4794 | 2117 * precision of the intra DC coefficient - 8 |
2118 * - encoding: Set by user. | |
1992 | 2119 * - decoding: unused |
2120 */ | |
2121 int intra_dc_precision; | |
2066 | 2122 |
2123 /** | |
4794 | 2124 * noise vs. sse weight for the nsse comparsion function |
2125 * - encoding: Set by user. | |
2066 | 2126 * - decoding: unused |
2127 */ | |
2128 int nsse_weight; | |
2095 | 2129 |
2130 /** | |
4794 | 2131 * Number of macroblock rows at the top which are skipped. |
2095 | 2132 * - encoding: unused |
4794 | 2133 * - decoding: Set by user. |
2095 | 2134 */ |
2135 int skip_top; | |
2136 | |
2137 /** | |
4794 | 2138 * Number of macroblock rows at the bottom which are skipped. |
2095 | 2139 * - encoding: unused |
4794 | 2140 * - decoding: Set by user. |
2095 | 2141 */ |
2142 int skip_bottom; | |
2167 | 2143 |
2144 /** | |
2145 * profile | |
4794 | 2146 * - encoding: Set by user. |
2147 * - decoding: Set by libavcodec. | |
2167 | 2148 */ |
2149 int profile; | |
2150 #define FF_PROFILE_UNKNOWN -99 | |
11047 | 2151 |
4891 | 2152 #define FF_PROFILE_AAC_MAIN 0 |
5590 | 2153 #define FF_PROFILE_AAC_LOW 1 |
2154 #define FF_PROFILE_AAC_SSR 2 | |
2155 #define FF_PROFILE_AAC_LTP 3 | |
2167 | 2156 |
11047 | 2157 #define FF_PROFILE_H264_BASELINE 66 |
2158 #define FF_PROFILE_H264_MAIN 77 | |
2159 #define FF_PROFILE_H264_EXTENDED 88 | |
2160 #define FF_PROFILE_H264_HIGH 100 | |
2161 #define FF_PROFILE_H264_HIGH_10 110 | |
2162 #define FF_PROFILE_H264_HIGH_422 122 | |
2163 #define FF_PROFILE_H264_HIGH_444 244 | |
2164 #define FF_PROFILE_H264_CAVLC_444 44 | |
2165 | |
2167 | 2166 /** |
2167 * level | |
4794 | 2168 * - encoding: Set by user. |
2169 * - decoding: Set by libavcodec. | |
2167 | 2170 */ |
2171 int level; | |
2172 #define FF_LEVEL_UNKNOWN -99 | |
2256 | 2173 |
2174 /** | |
4794 | 2175 * low resolution decoding, 1-> 1/2 size, 2->1/4 size |
2256 | 2176 * - encoding: unused |
4794 | 2177 * - decoding: Set by user. |
2256 | 2178 */ |
2179 int lowres; | |
2270 | 2180 |
2181 /** | |
4794 | 2182 * Bitstream width / height, may be different from width/height if lowres |
2183 * or other things are used. | |
2270 | 2184 * - encoding: unused |
4794 | 2185 * - decoding: Set by user before init if known. Codec should override / dynamically change if needed. |
2270 | 2186 */ |
2187 int coded_width, coded_height; | |
2381 | 2188 |
2189 /** | |
2190 * frame skip threshold | |
4794 | 2191 * - encoding: Set by user. |
2381 | 2192 * - decoding: unused |
2193 */ | |
2194 int frame_skip_threshold; | |
2195 | |
2196 /** | |
2197 * frame skip factor | |
4794 | 2198 * - encoding: Set by user. |
2381 | 2199 * - decoding: unused |
2200 */ | |
2201 int frame_skip_factor; | |
2382 | 2202 |
2203 /** | |
2204 * frame skip exponent | |
4794 | 2205 * - encoding: Set by user. |
2382 | 2206 * - decoding: unused |
2207 */ | |
2208 int frame_skip_exp; | |
2209 | |
2210 /** | |
4794 | 2211 * frame skip comparison function |
2212 * - encoding: Set by user. | |
2382 | 2213 * - decoding: unused |
2214 */ | |
2215 int frame_skip_cmp; | |
2493
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2216 |
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2217 /** |
4794 | 2218 * Border processing masking, raises the quantizer for mbs on the borders |
2493
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2219 * of the picture. |
4794 | 2220 * - encoding: Set by user. |
2493
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2221 * - decoding: unused |
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2222 */ |
258120c61eea
Border processing adaptive quant patch by (Christophe Massiot |cmassiot freebox fr)
michael
parents:
2492
diff
changeset
|
2223 float border_masking; |
2494
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2224 |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2225 /** |
4794 | 2226 * minimum MB lagrange multipler |
2227 * - encoding: Set by user. | |
2494
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2228 * - decoding: unused |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2229 */ |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2230 int mb_lmin; |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2231 |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2232 /** |
4794 | 2233 * maximum MB lagrange multipler |
2234 * - encoding: Set by user. | |
2494
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2235 * - decoding: unused |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2236 */ |
36d70fbb31c5
mb_lmin/max to limit the per mb quality for the ratecontrol independant from the frame limits
michael
parents:
2493
diff
changeset
|
2237 int mb_lmax; |
2584 | 2238 |
2239 /** | |
2967 | 2240 * |
4794 | 2241 * - encoding: Set by user. |
2584 | 2242 * - decoding: unused |
2243 */ | |
2244 int me_penalty_compensation; | |
2792 | 2245 |
2246 /** | |
2967 | 2247 * |
2792 | 2248 * - encoding: unused |
4794 | 2249 * - decoding: Set by user. |
2792 | 2250 */ |
2251 enum AVDiscard skip_loop_filter; | |
2252 | |
2253 /** | |
2967 | 2254 * |
2792 | 2255 * - encoding: unused |
4794 | 2256 * - decoding: Set by user. |
2792 | 2257 */ |
2258 enum AVDiscard skip_idct; | |
2259 | |
2260 /** | |
2967 | 2261 * |
2792 | 2262 * - encoding: unused |
4794 | 2263 * - decoding: Set by user. |
2792 | 2264 */ |
2265 enum AVDiscard skip_frame; | |
2983 | 2266 |
2267 /** | |
2268 * | |
4794 | 2269 * - encoding: Set by user. |
2983 | 2270 * - decoding: unused |
2271 */ | |
2272 int bidir_refine; | |
2990
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2273 |
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2274 /** |
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2275 * |
4794 | 2276 * - encoding: Set by user. |
2990
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2277 * - decoding: unused |
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2278 */ |
0300c2647bc3
support downscaling frames for dynamic b frame decission
michael
parents:
2983
diff
changeset
|
2279 int brd_scale; |
2996 | 2280 |
2281 /** | |
2282 * constant rate factor - quality-based VBR - values ~correspond to qps | |
4794 | 2283 * - encoding: Set by user. |
2996 | 2284 * - decoding: unused |
2285 */ | |
4030 | 2286 float crf; |
2996 | 2287 |
2288 /** | |
2289 * constant quantization parameter rate control method | |
4794 | 2290 * - encoding: Set by user. |
2996 | 2291 * - decoding: unused |
2292 */ | |
2293 int cqp; | |
2294 | |
2295 /** | |
4794 | 2296 * minimum GOP size |
2297 * - encoding: Set by user. | |
2996 | 2298 * - decoding: unused |
2299 */ | |
2300 int keyint_min; | |
2301 | |
2302 /** | |
2303 * number of reference frames | |
4794 | 2304 * - encoding: Set by user. |
8455 | 2305 * - decoding: Set by lavc. |
2996 | 2306 */ |
2307 int refs; | |
2308 | |
2309 /** | |
2310 * chroma qp offset from luma | |
4794 | 2311 * - encoding: Set by user. |
2996 | 2312 * - decoding: unused |
2313 */ | |
2314 int chromaoffset; | |
2315 | |
2316 /** | |
4794 | 2317 * Influences how often B-frames are used. |
2318 * - encoding: Set by user. | |
2996 | 2319 * - decoding: unused |
2320 */ | |
2321 int bframebias; | |
2322 | |
2323 /** | |
2324 * trellis RD quantization | |
4794 | 2325 * - encoding: Set by user. |
2996 | 2326 * - decoding: unused |
2327 */ | |
2328 int trellis; | |
2329 | |
2330 /** | |
4794 | 2331 * Reduce fluctuations in qp (before curve compression). |
2332 * - encoding: Set by user. | |
2996 | 2333 * - decoding: unused |
2334 */ | |
2335 float complexityblur; | |
2336 | |
2337 /** | |
2338 * in-loop deblocking filter alphac0 parameter | |
2339 * alpha is in the range -6...6 | |
4794 | 2340 * - encoding: Set by user. |
2996 | 2341 * - decoding: unused |
2342 */ | |
2343 int deblockalpha; | |
2344 | |
2345 /** | |
2346 * in-loop deblocking filter beta parameter | |
2347 * beta is in the range -6...6 | |
4794 | 2348 * - encoding: Set by user. |
2996 | 2349 * - decoding: unused |
2350 */ | |
2351 int deblockbeta; | |
2352 | |
2353 /** | |
2354 * macroblock subpartition sizes to consider - p8x8, p4x4, b8x8, i8x8, i4x4 | |
4794 | 2355 * - encoding: Set by user. |
2996 | 2356 * - decoding: unused |
2357 */ | |
2358 int partitions; | |
5967
15ed47af1838
Misc spelling fixes, prefer American over British English.
diego
parents:
5961
diff
changeset
|
2359 #define X264_PART_I4X4 0x001 /* Analyze i4x4 */ |
15ed47af1838
Misc spelling fixes, prefer American over British English.
diego
parents:
5961
diff
changeset
|
2360 #define X264_PART_I8X8 0x002 /* Analyze i8x8 (requires 8x8 transform) */ |
15ed47af1838
Misc spelling fixes, prefer American over British English.
diego
parents:
5961
diff
changeset
|
2361 #define X264_PART_P8X8 0x010 /* Analyze p16x8, p8x16 and p8x8 */ |
15ed47af1838
Misc spelling fixes, prefer American over British English.
diego
parents:
5961
diff
changeset
|
2362 #define X264_PART_P4X4 0x020 /* Analyze p8x4, p4x8, p4x4 */ |
15ed47af1838
Misc spelling fixes, prefer American over British English.
diego
parents:
5961
diff
changeset
|
2363 #define X264_PART_B8X8 0x100 /* Analyze b16x8, b8x16 and b8x8 */ |
2996 | 2364 |
2365 /** | |
7934 | 2366 * direct MV prediction mode - 0 (none), 1 (spatial), 2 (temporal), 3 (auto) |
4794 | 2367 * - encoding: Set by user. |
2996 | 2368 * - decoding: unused |
2369 */ | |
2370 int directpred; | |
3063
f02d0b59279c
Remove all stray tabs and trailing whitespace, this time for good.
diego
parents:
3061
diff
changeset
|
2371 |
3031
0f5f311f2f94
Parameter added for user to set the cutoff frequency when encoding with faac.
banan
parents:
3030
diff
changeset
|
2372 /** |
6083
77d27412c35d
use cutoff frequency to adjust bandwidth in ac3 encoder
jbr
parents:
6073
diff
changeset
|
2373 * Audio cutoff bandwidth (0 means "automatic") |
4794 | 2374 * - encoding: Set by user. |
3031
0f5f311f2f94
Parameter added for user to set the cutoff frequency when encoding with faac.
banan
parents:
3030
diff
changeset
|
2375 * - decoding: unused |
0f5f311f2f94
Parameter added for user to set the cutoff frequency when encoding with faac.
banan
parents:
3030
diff
changeset
|
2376 */ |
0f5f311f2f94
Parameter added for user to set the cutoff frequency when encoding with faac.
banan
parents:
3030
diff
changeset
|
2377 int cutoff; |
3061 | 2378 |
2379 /** | |
4794 | 2380 * Multiplied by qscale for each frame and added to scene_change_score. |
2381 * - encoding: Set by user. | |
3061 | 2382 * - decoding: unused |
2383 */ | |
2384 int scenechange_factor; | |
3293 | 2385 |
2386 /** | |
2387 * | |
4794 | 2388 * Note: Value depends upon the compare function used for fullpel ME. |
2389 * - encoding: Set by user. | |
3293 | 2390 * - decoding: unused |
2391 */ | |
2392 int mv0_threshold; | |
3335
97af1b315f59
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents:
3329
diff
changeset
|
2393 |
97af1b315f59
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents:
3329
diff
changeset
|
2394 /** |
4794 | 2395 * Adjusts sensitivity of b_frame_strategy 1. |
2396 * - encoding: Set by user. | |
3335
97af1b315f59
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents:
3329
diff
changeset
|
2397 * - decoding: unused |
97af1b315f59
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents:
3329
diff
changeset
|
2398 */ |
97af1b315f59
Make B-frame reduction sensitivity by b_strategy/vb_strategy = 1
corey
parents:
3329
diff
changeset
|
2399 int b_sensitivity; |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2400 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2401 /** |
4794 | 2402 * - encoding: Set by user. |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2403 * - decoding: unused |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2404 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2405 int compression_level; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2406 #define FF_COMPRESSION_DEFAULT -1 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2407 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2408 /** |
4794 | 2409 * Sets whether to use LPC mode - used by FLAC encoder. |
2410 * - encoding: Set by user. | |
2411 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2412 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2413 int use_lpc; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2414 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2415 /** |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2416 * LPC coefficient precision - used by FLAC encoder |
4794 | 2417 * - encoding: Set by user. |
2418 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2419 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2420 int lpc_coeff_precision; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2421 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2422 /** |
4794 | 2423 * - encoding: Set by user. |
2424 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2425 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2426 int min_prediction_order; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2427 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2428 /** |
4794 | 2429 * - encoding: Set by user. |
2430 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2431 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2432 int max_prediction_order; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2433 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2434 /** |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2435 * search method for selecting prediction order |
4794 | 2436 * - encoding: Set by user. |
2437 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2438 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2439 int prediction_order_method; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2440 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2441 /** |
4794 | 2442 * - encoding: Set by user. |
2443 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2444 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2445 int min_partition_order; |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2446 |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2447 /** |
4794 | 2448 * - encoding: Set by user. |
2449 * - decoding: unused | |
3385
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2450 */ |
340e5d35b326
flac-lpc patch by (Justin Ruggles jruggle earthlink net)
michael
parents:
3359
diff
changeset
|
2451 int max_partition_order; |
4158
47d1b5261f17
add option to set mpeg1/2 gop timecode start, and drop frame flag timecode flag
bcoudurier
parents:
4154
diff
changeset
|
2452 |
47d1b5261f17
add option to set mpeg1/2 gop timecode start, and drop frame flag timecode flag
bcoudurier
parents:
4154
diff
changeset
|
2453 /** |
47d1b5261f17
add option to set mpeg1/2 gop timecode start, and drop frame flag timecode flag
bcoudurier
parents:
4154
diff
changeset
|
2454 * GOP timecode frame start number, in non drop frame format |
4794 | 2455 * - encoding: Set by user. |
2456 * - decoding: unused | |
4158
47d1b5261f17
add option to set mpeg1/2 gop timecode start, and drop frame flag timecode flag
bcoudurier
parents:
4154
diff
changeset
|
2457 */ |
47d1b5261f17
add option to set mpeg1/2 gop timecode start, and drop frame flag timecode flag
bcoudurier
parents:
4154
diff
changeset
|
2458 int64_t timecode_frame_start; |
5576
1a92e129a679
Add request_channels member to AVCodecContext so we now have a proper
reimar
parents:
5566
diff
changeset
|
2459 |
8098 | 2460 #if LIBAVCODEC_VERSION_MAJOR < 53 |
5576
1a92e129a679
Add request_channels member to AVCodecContext so we now have a proper
reimar
parents:
5566
diff
changeset
|
2461 /** |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2462 * Decoder should decode to this many channels if it can (0 for default) |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2463 * - encoding: unused |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2464 * - decoding: Set by user. |
8098 | 2465 * @deprecated Deprecated in favor of request_channel_layout. |
5576
1a92e129a679
Add request_channels member to AVCodecContext so we now have a proper
reimar
parents:
5566
diff
changeset
|
2466 */ |
1a92e129a679
Add request_channels member to AVCodecContext so we now have a proper
reimar
parents:
5566
diff
changeset
|
2467 int request_channels; |
8098 | 2468 #endif |
6047
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2469 |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2470 /** |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2471 * Percentage of dynamic range compression to be applied by the decoder. |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2472 * The default value is 1.0, corresponding to full compression. |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2473 * - encoding: unused |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2474 * - decoding: Set by user. |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2475 */ |
2f9c17454842
Add option for user to scale the amount of dynamic range compression which is
jbr
parents:
6044
diff
changeset
|
2476 float drc_scale; |
7631
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2477 |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2478 /** |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2479 * opaque 64bit number (generally a PTS) that will be reordered and |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2480 * output in AVFrame.reordered_opaque |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2481 * - encoding: unused |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2482 * - decoding: Set by user. |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2483 */ |
b5b4bf0944b8
Provide a simpler way for the user to reorder her timestamps.
michael
parents:
7621
diff
changeset
|
2484 int64_t reordered_opaque; |
7721 | 2485 |
2486 /** | |
2487 * Bits per sample/pixel of internal libavcodec pixel/sample format. | |
2488 * This field is applicable only when sample_fmt is SAMPLE_FMT_S32. | |
2489 * - encoding: set by user. | |
2490 * - decoding: set by libavcodec. | |
2491 */ | |
2492 int bits_per_raw_sample; | |
8098 | 2493 |
2494 /** | |
2495 * Audio channel layout. | |
2496 * - encoding: set by user. | |
2497 * - decoding: set by libavcodec. | |
2498 */ | |
2499 int64_t channel_layout; | |
2500 | |
2501 /** | |
2502 * Request decoder to use this channel layout if it can (0 for default) | |
2503 * - encoding: unused | |
2504 * - decoding: Set by user. | |
2505 */ | |
2506 int64_t request_channel_layout; | |
8227 | 2507 |
2508 /** | |
2509 * Ratecontrol attempt to use, at maximum, <value> of what can be used without an underflow. | |
2510 * - encoding: Set by user. | |
2511 * - decoding: unused. | |
2512 */ | |
2513 float rc_max_available_vbv_use; | |
2514 | |
2515 /** | |
2516 * Ratecontrol attempt to use, at least, <value> times the amount needed to prevent a vbv overflow. | |
2517 * - encoding: Set by user. | |
2518 * - decoding: unused. | |
2519 */ | |
2520 float rc_min_vbv_overflow_use; | |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2521 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2522 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2523 * Hardware accelerator in use |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2524 * - encoding: unused. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2525 * - decoding: Set by libavcodec |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2526 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2527 struct AVHWAccel *hwaccel; |
9059
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2528 |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2529 /** |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2530 * For some codecs, the time base is closer to the field rate than the frame rate. |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2531 * Most notably, H.264 and MPEG-2 specify time_base as half of frame duration |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2532 * if no telecine is used ... |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2533 * |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2534 * Set to time_base ticks per frame. Default 1, e.g., H.264/MPEG-2 set it to 2. |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2535 */ |
3c5920f57063
Add ticks_per_frame, this should hopefully fix the regressions caused
michael
parents:
9050
diff
changeset
|
2536 int ticks_per_frame; |
9182
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2537 |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2538 /** |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2539 * Hardware accelerator context. |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2540 * For some hardware accelerators, a global context needs to be |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2541 * provided by the user. In that case, this holds display-dependent |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2542 * data FFmpeg cannot instantiate itself. Please refer to the |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2543 * FFmpeg HW accelerator documentation to know how to fill this |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2544 * is. e.g. for VA API, this is a struct vaapi_context. |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2545 * - encoding: unused |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2546 * - decoding: Set by user |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2547 */ |
12f23f37664b
Amend AVCodecContext with hwaccel_context (HW accelerator context).
gb
parents:
9161
diff
changeset
|
2548 void *hwaccel_context; |
9600 | 2549 |
2550 /** | |
2551 * Chromaticity coordinates of the source primaries. | |
2552 * - encoding: Set by user | |
2553 * - decoding: Set by libavcodec | |
2554 */ | |
2555 enum AVColorPrimaries color_primaries; | |
2556 | |
2557 /** | |
2558 * Color Transfer Characteristic. | |
2559 * - encoding: Set by user | |
2560 * - decoding: Set by libavcodec | |
2561 */ | |
2562 enum AVColorTransferCharacteristic color_trc; | |
2563 | |
2564 /** | |
2565 * YUV colorspace type. | |
2566 * - encoding: Set by user | |
2567 * - decoding: Set by libavcodec | |
2568 */ | |
2569 enum AVColorSpace colorspace; | |
2570 | |
2571 /** | |
2572 * MPEG vs JPEG YUV range. | |
2573 * - encoding: Set by user | |
2574 * - decoding: Set by libavcodec | |
2575 */ | |
2576 enum AVColorRange color_range; | |
9626
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2577 |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2578 /** |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2579 * This defines the location of chroma samples. |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2580 * - encoding: Set by user |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2581 * - decoding: Set by libavcodec |
bd3e11b60ccd
Add a chroma_sample_location field to define positioning of chroma samples
conrad
parents:
9616
diff
changeset
|
2582 */ |
10318 | 2583 enum AVChromaLocation chroma_sample_location; |
10386
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2584 |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2585 /** |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2586 * The codec may call this to execute several independent things. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2587 * It will return only after finishing all tasks. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2588 * The user may replace this with some multithreaded implementation, |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2589 * the default implementation will execute the parts serially. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2590 * Also see avcodec_thread_init and e.g. the --enable-pthread configure option. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2591 * @param c context passed also to func |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2592 * @param count the number of things to execute |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2593 * @param arg2 argument passed unchanged to func |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2594 * @param ret return values of executed functions, must have space for "count" values. May be NULL. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2595 * @param func function that will be called count times, with jobnr from 0 to count-1. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2596 * threadnr will be in the range 0 to c->thread_count-1 < MAX_THREADS and so that no |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2597 * two instances of func executing at the same time will have the same threadnr. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2598 * @return always 0 currently, but code should handle a future improvement where when any call to func |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2599 * returns < 0 no further calls to func may be done and < 0 is returned. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2600 * - encoding: Set by libavcodec, user can override. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2601 * - decoding: Set by libavcodec, user can override. |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2602 */ |
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
2603 int (*execute2)(struct AVCodecContext *c, int (*func)(struct AVCodecContext *c2, void *arg, int jobnr, int threadnr), void *arg2, int *ret, int count); |
10566 | 2604 |
2605 /** | |
2606 * explicit P-frame weighted prediction analysis method | |
2607 * 0: off | |
2608 * 1: fast blind weighting (one reference duplicate with -1 offset) | |
2609 * 2: smart weighting (full fade detection analysis) | |
2610 * - encoding: Set by user. | |
2611 * - decoding: unused | |
2612 */ | |
2613 int weighted_p_pred; | |
11538
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2614 |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2615 /** |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2616 * AQ mode |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2617 * 0: Disabled |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2618 * 1: Variance AQ (complexity mask) |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2619 * 2: Auto-variance AQ (experimental) |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2620 * - encoding: Set by user |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2621 * - decoding: unused |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2622 */ |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2623 int aq_mode; |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2624 |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2625 /** |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2626 * AQ strength |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2627 * Reduces blocking and blurring in flat and textured areas. |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2628 * - encoding: Set by user |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2629 * - decoding: unused |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2630 */ |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2631 float aq_strength; |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2632 |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2633 /** |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2634 * PSY RD |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2635 * Strength of psychovisual optimization |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2636 * - encoding: Set by user |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2637 * - decoding: unused |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2638 */ |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2639 float psy_rd; |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2640 |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2641 /** |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2642 * PSY trellis |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2643 * Strength of psychovisual optimization |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2644 * - encoding: Set by user |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2645 * - decoding: unused |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2646 */ |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2647 float psy_trellis; |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2648 |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2649 /** |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2650 * RC lookahead |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2651 * Number of frames for frametype and ratecontrol lookahead |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2652 * - encoding: Set by user |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2653 * - decoding: unused |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2654 */ |
9beb570426f4
Enable more libx264 options, aq, psy, rc lookahead and ssim
bcoudurier
parents:
11536
diff
changeset
|
2655 int rc_lookahead; |
11689
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2656 |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2657 /** |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2658 * Constant rate factor maximum |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2659 * With CRF encoding mode and VBV restrictions enabled, prevents quality from being worse |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2660 * than crf_max, even if doing so would violate VBV restrictions. |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2661 * - encoding: Set by user. |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2662 * - decoding: unused |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2663 */ |
2312dfbe9251
Add intra refresh and crf-max support to the libavcodec libx264 wrapper.
darkshikari
parents:
11674
diff
changeset
|
2664 float crf_max; |
11741 | 2665 |
2666 int log_level_offset; | |
0 | 2667 } AVCodecContext; |
2668 | |
1112
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
2669 /** |
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
2670 * AVCodec. |
54be6aece1be
more cosmetics so that doxygen output is readable ...
michaelni
parents:
1105
diff
changeset
|
2671 */ |
0 | 2672 typedef struct AVCodec { |
5139 | 2673 /** |
2674 * Name of the codec implementation. | |
2675 * The name is globally unique among encoders and among decoders (but an | |
2676 * encoder and a decoder can share the same name). | |
2677 * This is the primary way to find a codec from the user perspective. | |
2678 */ | |
862 | 2679 const char *name; |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
2680 enum AVMediaType type; |
2322 | 2681 enum CodecID id; |
0 | 2682 int priv_data_size; |
2683 int (*init)(AVCodecContext *); | |
1064 | 2684 int (*encode)(AVCodecContext *, uint8_t *buf, int buf_size, void *data); |
0 | 2685 int (*close)(AVCodecContext *); |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
2686 int (*decode)(AVCodecContext *, void *outdata, int *outdata_size, AVPacket *avpkt); |
6520 | 2687 /** |
2688 * Codec capabilities. | |
2689 * see CODEC_CAP_* | |
2690 */ | |
67 | 2691 int capabilities; |
0 | 2692 struct AVCodec *next; |
6521 | 2693 /** |
2694 * Flush buffers. | |
2695 * Will be called when seeking | |
2696 */ | |
1368 | 2697 void (*flush)(AVCodecContext *); |
6629 | 2698 const AVRational *supported_framerates; ///< array of supported framerates, or NULL if any, array is terminated by {0,0} |
6630 | 2699 const enum PixelFormat *pix_fmts; ///< array of supported pixel formats, or NULL if unknown, array is terminated by -1 |
7040
e943e1409077
Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents:
7034
diff
changeset
|
2700 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
2701 * Descriptive name for the codec, meant to be more human readable than name. |
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
2702 * You should use the NULL_IF_CONFIG_SMALL() macro to define it. |
7040
e943e1409077
Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents:
7034
diff
changeset
|
2703 */ |
e943e1409077
Make AVCodec long_names definition conditional depending on CONFIG_SMALL.
stefano
parents:
7034
diff
changeset
|
2704 const char *long_name; |
6664 | 2705 const int *supported_samplerates; ///< array of supported audio samplerates, or NULL if unknown, array is terminated by 0 |
7410
4c68f77c49ee
add sample_fmts infrastructure: AVCodec->sample_fmts and SAMPLE_FMT_NB enum.
pross
parents:
7409
diff
changeset
|
2706 const enum SampleFormat *sample_fmts; ///< array of supported sample formats, or NULL if unknown, array is terminated by -1 |
8098 | 2707 const int64_t *channel_layouts; ///< array of support channel layouts, or NULL if unknown. array is terminated by 0 |
0 | 2708 } AVCodec; |
2709 | |
1058 | 2710 /** |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2711 * AVHWAccel. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2712 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2713 typedef struct AVHWAccel { |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2714 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2715 * Name of the hardware accelerated codec. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2716 * The name is globally unique among encoders and among decoders (but an |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2717 * encoder and a decoder can share the same name). |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2718 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2719 const char *name; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2720 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2721 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2722 * Type of codec implemented by the hardware accelerator. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2723 * |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
2724 * See AVMEDIA_TYPE_xxx |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2725 */ |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
2726 enum AVMediaType type; |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2727 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2728 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2729 * Codec implemented by the hardware accelerator. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2730 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2731 * See CODEC_ID_xxx |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2732 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2733 enum CodecID id; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2734 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2735 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2736 * Supported pixel format. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2737 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2738 * Only hardware accelerated formats are supported here. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2739 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2740 enum PixelFormat pix_fmt; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2741 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2742 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2743 * Hardware accelerated codec capabilities. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2744 * see FF_HWACCEL_CODEC_CAP_* |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2745 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2746 int capabilities; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2747 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2748 struct AVHWAccel *next; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2749 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2750 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2751 * Called at the beginning of each frame or field picture. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2752 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2753 * Meaningful frame information (codec specific) is guaranteed to |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2754 * be parsed at this point. This function is mandatory. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2755 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
2756 * Note that buf can be NULL along with buf_size set to 0. |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2757 * Otherwise, this means the whole frame is available at this point. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2758 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2759 * @param avctx the codec context |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2760 * @param buf the frame data buffer base |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2761 * @param buf_size the size of the frame in bytes |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2762 * @return zero if successful, a negative value otherwise |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2763 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2764 int (*start_frame)(AVCodecContext *avctx, const uint8_t *buf, uint32_t buf_size); |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2765 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2766 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2767 * Callback for each slice. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2768 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2769 * Meaningful slice information (codec specific) is guaranteed to |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2770 * be parsed at this point. This function is mandatory. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2771 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2772 * @param avctx the codec context |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2773 * @param buf the slice data buffer base |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2774 * @param buf_size the size of the slice in bytes |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2775 * @return zero if successful, a negative value otherwise |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2776 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2777 int (*decode_slice)(AVCodecContext *avctx, const uint8_t *buf, uint32_t buf_size); |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2778 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2779 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2780 * Called at the end of each frame or field picture. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2781 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2782 * The whole picture is parsed at this point and can now be sent |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2783 * to the hardware accelerator. This function is mandatory. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2784 * |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2785 * @param avctx the codec context |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2786 * @return zero if successful, a negative value otherwise |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2787 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2788 int (*end_frame)(AVCodecContext *avctx); |
9155 | 2789 |
2790 /** | |
2791 * Size of HW accelerator private data. | |
2792 * | |
9161 | 2793 * Private data is allocated with av_mallocz() before |
2794 * AVCodecContext.get_buffer() and deallocated after | |
2795 * AVCodecContext.release_buffer(). | |
9155 | 2796 */ |
2797 int priv_data_size; | |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2798 } AVHWAccel; |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2799 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
2800 /** |
842
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
2801 * four components are given, that's all. |
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
2802 * the last component is alpha |
e460775adb38
cleanup (breaks compatibility, requested by fabrice)
michaelni
parents:
831
diff
changeset
|
2803 */ |
0 | 2804 typedef struct AVPicture { |
1064 | 2805 uint8_t *data[4]; |
1299 | 2806 int linesize[4]; ///< number of bytes per line |
0 | 2807 } AVPicture; |
2808 | |
9218
18dffa8f2382
Remove deprecated functions and structures on next version bump.
diego
parents:
9217
diff
changeset
|
2809 #if LIBAVCODEC_VERSION_MAJOR < 53 |
1462 | 2810 /** |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2811 * AVPaletteControl |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2812 * This structure defines a method for communicating palette changes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2813 * between and demuxer and a decoder. |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2814 * |
4889
beeb03aad909
patch so that the deprecated items show up correctly
benoit
parents:
4884
diff
changeset
|
2815 * @deprecated Use AVPacket to send palette changes instead. |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
2816 * This is totally broken. |
1462 | 2817 */ |
1594
6d37b161cf85
Fix some palette related defines, bump build number
rtognimp
parents:
1585
diff
changeset
|
2818 #define AVPALETTE_SIZE 1024 |
1596 | 2819 #define AVPALETTE_COUNT 256 |
1462 | 2820 typedef struct AVPaletteControl { |
2821 | |
4794 | 2822 /* Demuxer sets this to 1 to indicate the palette has changed; |
2823 * decoder resets to 0. */ | |
1462 | 2824 int palette_changed; |
2825 | |
1585
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2826 /* 4-byte ARGB palette entries, stored in native byte order; note that |
6b224ca24033
revised palette API, courtesy of Roberto Togni (rtogni at freemail.it)
melanson
parents:
1582
diff
changeset
|
2827 * the individual palette components should be on a 8-bit scale; if |
4794 | 2828 * the palette data comes from an IBM VGA native format, the component |
2829 * data is probably 6 bits in size and needs to be scaled. */ | |
1594
6d37b161cf85
Fix some palette related defines, bump build number
rtognimp
parents:
1585
diff
changeset
|
2830 unsigned int palette[AVPALETTE_COUNT]; |
1462 | 2831 |
3797
0596dbc4f858
marking AVPaletteControl as deprecated due to thread saftey amongth other issues (it doesnt work if theres any delay between demuxer and decoder)
michael
parents:
3772
diff
changeset
|
2832 } AVPaletteControl attribute_deprecated; |
9218
18dffa8f2382
Remove deprecated functions and structures on next version bump.
diego
parents:
9217
diff
changeset
|
2833 #endif |
1462 | 2834 |
8511 | 2835 enum AVSubtitleType { |
2836 SUBTITLE_NONE, | |
2837 | |
2838 SUBTITLE_BITMAP, ///< A bitmap, pict will be set | |
2839 | |
2840 /** | |
2841 * Plain text, the text field must be set by the decoder and is | |
2842 * authoritative. ass and pict fields may contain approximations. | |
2843 */ | |
2844 SUBTITLE_TEXT, | |
2845 | |
2846 /** | |
2847 * Formatted text, the ass field must be set by the decoder and is | |
2848 * authoritative. pict and text fields may contain approximations. | |
2849 */ | |
2850 SUBTITLE_ASS, | |
2851 }; | |
2852 | |
2796
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2853 typedef struct AVSubtitleRect { |
8515
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2854 int x; ///< top left corner of pict, undefined when pict is not set |
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2855 int y; ///< top left corner of pict, undefined when pict is not set |
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2856 int w; ///< width of pict, undefined when pict is not set |
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2857 int h; ///< height of pict, undefined when pict is not set |
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2858 int nb_colors; ///< number of colors in pict, undefined when pict is not set |
8516
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2859 |
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2860 /** |
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2861 * data+linesize for the bitmap of this subtitle. |
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2862 * can be set for text/ass as well once they where rendered |
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2863 */ |
315b302fcd1d
Replace AVSubtitleRect.rgba_palette and bitmap by AVPicture.
michael
parents:
8515
diff
changeset
|
2864 AVPicture pict; |
8517 | 2865 enum AVSubtitleType type; |
2866 | |
2867 char *text; ///< 0 terminated plain UTF-8 text | |
2868 | |
2869 /** | |
2870 * 0 terminated ASS/SSA compatible event line. | |
2871 * The pressentation of this is unaffected by the other values in this | |
2872 * struct. | |
2873 */ | |
2874 char *ass; | |
2796
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2875 } AVSubtitleRect; |
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2876 |
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2877 typedef struct AVSubtitle { |
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2878 uint16_t format; /* 0 = graphics */ |
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2879 uint32_t start_display_time; /* relative to packet pts, in ms */ |
95c35706acbb
DVB subtitle decoder by (Ian Caulfield: imc25, cam ac uk)
michael
parents:
2794
diff
changeset
|
2880 uint32_t end_display_time; /* relative to packet pts, in ms */ |
8515
45506d633cdc
Replace some fixed width variable from AVSubtitle* by normal int.
michael
parents:
8513
diff
changeset
|
2881 unsigned num_rects; |
8512
aa45029f5cd7
Change AVSubtitle.rects to an array of pointers so ABI does not break
michael
parents:
8511
diff
changeset
|
2882 AVSubtitleRect **rects; |
9866
876dc7d26ec1
Add pts field to AVSubtitle, for use by future XSUB encoder (and XSUB decoder
reimar
parents:
9848
diff
changeset
|
2883 int64_t pts; ///< Same as packet pts, in AV_TIME_BASE |
2756 | 2884 } AVSubtitle; |
2885 | |
9357
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2886 /* packet functions */ |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2887 |
9394
d322325fc00e
Get rid of av_destruct_packet_nofree and use NULL instead.
reimar
parents:
9360
diff
changeset
|
2888 /** |
d322325fc00e
Get rid of av_destruct_packet_nofree and use NULL instead.
reimar
parents:
9360
diff
changeset
|
2889 * @deprecated use NULL instead |
d322325fc00e
Get rid of av_destruct_packet_nofree and use NULL instead.
reimar
parents:
9360
diff
changeset
|
2890 */ |
d322325fc00e
Get rid of av_destruct_packet_nofree and use NULL instead.
reimar
parents:
9360
diff
changeset
|
2891 attribute_deprecated void av_destruct_packet_nofree(AVPacket *pkt); |
9357
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2892 |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2893 /** |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2894 * Default packet destructor. |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2895 */ |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2896 void av_destruct_packet(AVPacket *pkt); |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2897 |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2898 /** |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2899 * Initialize optional fields of a packet with default values. |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2900 * |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2901 * @param pkt packet |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2902 */ |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2903 void av_init_packet(AVPacket *pkt); |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2904 |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2905 /** |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2906 * Allocate the payload of a packet and initialize its fields with |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2907 * default values. |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2908 * |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2909 * @param pkt packet |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2910 * @param size wanted payload size |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2911 * @return 0 if OK, AVERROR_xxx otherwise |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2912 */ |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2913 int av_new_packet(AVPacket *pkt, int size); |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2914 |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2915 /** |
9360
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2916 * Reduce packet size, correctly zeroing padding |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2917 * |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2918 * @param pkt packet |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2919 * @param size new size |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2920 */ |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2921 void av_shrink_packet(AVPacket *pkt, int size); |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2922 |
66e270967340
Add av_shrink_packet function for use in av_get_packet that reduces pkt->size
reimar
parents:
9359
diff
changeset
|
2923 /** |
9357
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2924 * @warning This is a hack - the packet memory allocation stuff is broken. The |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2925 * packet is allocated if it was not really allocated. |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2926 */ |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2927 int av_dup_packet(AVPacket *pkt); |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2928 |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2929 /** |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2930 * Free a packet. |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2931 * |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2932 * @param pkt packet to free |
2108342734cc
Move av_packet_*() functions from libavformat/ to libavcodec/, where the
rbultje
parents:
9355
diff
changeset
|
2933 */ |
9584 | 2934 void av_free_packet(AVPacket *pkt); |
2756 | 2935 |
0 | 2936 /* resample.c */ |
2937 | |
2938 struct ReSampleContext; | |
2082
3dc9bbe1b152
polyphase kaiser windowed sinc and blackman nuttall windowed sinc audio resample filters
michael
parents:
2066
diff
changeset
|
2939 struct AVResampleContext; |
0 | 2940 |
2941 typedef struct ReSampleContext ReSampleContext; | |
2942 | |
8806
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2943 #if LIBAVCODEC_VERSION_MAJOR < 53 |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2944 /** |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2945 * @deprecated Use av_audio_resample_init() instead. |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2946 */ |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2947 attribute_deprecated ReSampleContext *audio_resample_init(int output_channels, int input_channels, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2948 int output_rate, int input_rate); |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2949 #endif |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2950 /** |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2951 * Initializes audio resampling context |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2952 * |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2953 * @param output_channels number of output channels |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2954 * @param input_channels number of input channels |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2955 * @param output_rate output sample rate |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2956 * @param input_rate input sample rate |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2957 * @param sample_fmt_out requested output sample format |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2958 * @param sample_fmt_in input sample format |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2959 * @param filter_length length of each FIR filter in the filterbank relative to the cutoff freq |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2960 * @param log2_phase_count log2 of the number of entries in the polyphase filterbank |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2961 * @param linear If 1 then the used FIR filter will be linearly interpolated |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2962 between the 2 closest, if 0 the closest will be used |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2963 * @param cutoff cutoff frequency, 1.0 corresponds to half the output sampling rate |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2964 * @return allocated ReSampleContext, NULL if error occured |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2965 */ |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2966 ReSampleContext *av_audio_resample_init(int output_channels, int input_channels, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2967 int output_rate, int input_rate, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2968 enum SampleFormat sample_fmt_out, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2969 enum SampleFormat sample_fmt_in, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2970 int filter_length, int log2_phase_count, |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2971 int linear, double cutoff); |
cbeaa8c0fe4f
extend resampling API, add S16 internal conversion
bcoudurier
parents:
8779
diff
changeset
|
2972 |
0 | 2973 int audio_resample(ReSampleContext *s, short *output, short *input, int nb_samples); |
2974 void audio_resample_close(ReSampleContext *s); | |
2975 | |
8778
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2976 |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2977 /** |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2978 * Initializes an audio resampler. |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2979 * Note, if either rate is not an integer then simply scale both rates up so they are. |
8779
062adf954a56
Try to doxyfy av_resample_init(). I hope I did not misremember anything as I
michael
parents:
8778
diff
changeset
|
2980 * @param filter_length length of each FIR filter in the filterbank relative to the cutoff freq |
062adf954a56
Try to doxyfy av_resample_init(). I hope I did not misremember anything as I
michael
parents:
8778
diff
changeset
|
2981 * @param log2_phase_count log2 of the number of entries in the polyphase filterbank |
062adf954a56
Try to doxyfy av_resample_init(). I hope I did not misremember anything as I
michael
parents:
8778
diff
changeset
|
2982 * @param linear If 1 then the used FIR filter will be linearly interpolated |
062adf954a56
Try to doxyfy av_resample_init(). I hope I did not misremember anything as I
michael
parents:
8778
diff
changeset
|
2983 between the 2 closest, if 0 the closest will be used |
062adf954a56
Try to doxyfy av_resample_init(). I hope I did not misremember anything as I
michael
parents:
8778
diff
changeset
|
2984 * @param cutoff cutoff frequency, 1.0 corresponds to half the output sampling rate |
8778
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2985 */ |
2308 | 2986 struct AVResampleContext *av_resample_init(int out_rate, int in_rate, int filter_length, int log2_phase_count, int linear, double cutoff); |
8778
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2987 |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2988 /** |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2989 * resamples. |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2990 * @param src an array of unconsumed samples |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2991 * @param consumed the number of samples of src which have been consumed are returned here |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2992 * @param src_size the number of unconsumed samples available |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2993 * @param dst_size the amount of space in samples available in dst |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2994 * @param update_ctx If this is 0 then the context will not be modified, that way several channels can be resampled with the same context. |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2995 * @return the number of samples written in dst or -1 if an error occurred |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2996 */ |
2082
3dc9bbe1b152
polyphase kaiser windowed sinc and blackman nuttall windowed sinc audio resample filters
michael
parents:
2066
diff
changeset
|
2997 int av_resample(struct AVResampleContext *c, short *dst, short *src, int *consumed, int src_size, int dst_size, int update_ctx); |
8778
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2998 |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
2999 |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3000 /** |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3001 * Compensates samplerate/timestamp drift. The compensation is done by changing |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3002 * the resampler parameters, so no audible clicks or similar distortions occur |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3003 * @param compensation_distance distance in output samples over which the compensation should be performed |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3004 * @param sample_delta number of output samples which should be output less |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3005 * |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3006 * example: av_resample_compensate(c, 10, 500) |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3007 * here instead of 510 samples only 500 samples would be output |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3008 * |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3009 * note, due to rounding the actual compensation might be slightly different, |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3010 * especially if the compensation_distance is large and the in_rate used during init is small |
bdb11e2330d1
Move doxy for public resample2 functions to the public header.
michael
parents:
8761
diff
changeset
|
3011 */ |
2108 | 3012 void av_resample_compensate(struct AVResampleContext *c, int sample_delta, int compensation_distance); |
2117
a21b80c71d88
av_resample_close in avcodec.h patch by ("William Juwono" <william.juwono at sensestream dot com>)
michael
parents:
2108
diff
changeset
|
3013 void av_resample_close(struct AVResampleContext *c); |
2082
3dc9bbe1b152
polyphase kaiser windowed sinc and blackman nuttall windowed sinc audio resample filters
michael
parents:
2066
diff
changeset
|
3014 |
1508 | 3015 /** |
3016 * Allocate memory for a picture. Call avpicture_free to free it. | |
3017 * | |
4794 | 3018 * @param picture the picture to be filled in |
3019 * @param pix_fmt the format of the picture | |
3020 * @param width the width of the picture | |
3021 * @param height the height of the picture | |
3022 * @return zero if successful, a negative value if not | |
1508 | 3023 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3024 int avpicture_alloc(AVPicture *picture, enum PixelFormat pix_fmt, int width, int height); |
1508 | 3025 |
4568
ad50768a5b57
Doxygenize the comments for the avpicture_free() function.
takis
parents:
4567
diff
changeset
|
3026 /** |
ad50768a5b57
Doxygenize the comments for the avpicture_free() function.
takis
parents:
4567
diff
changeset
|
3027 * Free a picture previously allocated by avpicture_alloc(). |
ad50768a5b57
Doxygenize the comments for the avpicture_free() function.
takis
parents:
4567
diff
changeset
|
3028 * |
4794 | 3029 * @param picture the AVPicture to be freed |
4568
ad50768a5b57
Doxygenize the comments for the avpicture_free() function.
takis
parents:
4567
diff
changeset
|
3030 */ |
1508 | 3031 void avpicture_free(AVPicture *picture); |
3032 | |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3033 /** |
4794 | 3034 * Fill in the AVPicture fields. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3035 * The fields of the given AVPicture are filled in by using the 'ptr' address |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3036 * which points to the image data buffer. Depending on the specified picture |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3037 * format, one or multiple image data pointers and line sizes will be set. |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3038 * If a planar format is specified, several pointers will be set pointing to |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3039 * the different picture planes and the line sizes of the different planes |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3040 * will be stored in the lines_sizes array. |
9217
53ec03e7ba40
Fix avpicture_get_size for non-paletted formats with a helper palette
reimar
parents:
9200
diff
changeset
|
3041 * Call with ptr == NULL to get the required size for the ptr buffer. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3042 * |
4794 | 3043 * @param picture AVPicture whose fields are to be filled in |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3044 * @param ptr Buffer which will contain or contains the actual image data |
4794 | 3045 * @param pix_fmt The format in which the picture data is stored. |
3046 * @param width the width of the image in pixels | |
3047 * @param height the height of the image in pixels | |
3048 * @return size of the image data in bytes | |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3049 */ |
1064 | 3050 int avpicture_fill(AVPicture *picture, uint8_t *ptr, |
9902
9bdf9fe9018c
Fix argument type mismatches for av_picture_crop and av_picture_fill
mru
parents:
9893
diff
changeset
|
3051 enum PixelFormat pix_fmt, int width, int height); |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3052 int avpicture_layout(const AVPicture* src, enum PixelFormat pix_fmt, int width, int height, |
1231
b88dfc4bbf8c
* introducing new public interface in imgconvert.c
romansh
parents:
1224
diff
changeset
|
3053 unsigned char *dest, int dest_size); |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3054 |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3055 /** |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3056 * Calculate the size in bytes that a picture of the given width and height |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3057 * would occupy if stored in the given picture format. |
9217
53ec03e7ba40
Fix avpicture_get_size for non-paletted formats with a helper palette
reimar
parents:
9200
diff
changeset
|
3058 * Note that this returns the size of a compact representation as generated |
53ec03e7ba40
Fix avpicture_get_size for non-paletted formats with a helper palette
reimar
parents:
9200
diff
changeset
|
3059 * by avpicture_layout, which can be smaller than the size required for e.g. |
53ec03e7ba40
Fix avpicture_get_size for non-paletted formats with a helper palette
reimar
parents:
9200
diff
changeset
|
3060 * avpicture_fill. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3061 * |
4794 | 3062 * @param pix_fmt the given picture format |
3063 * @param width the width of the image | |
3064 * @param height the height of the image | |
9217
53ec03e7ba40
Fix avpicture_get_size for non-paletted formats with a helper palette
reimar
parents:
9200
diff
changeset
|
3065 * @return Image data size in bytes or -1 on error (e.g. too large dimensions). |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3066 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3067 int avpicture_get_size(enum PixelFormat pix_fmt, int width, int height); |
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3068 void avcodec_get_chroma_sub_sample(enum PixelFormat pix_fmt, int *h_shift, int *v_shift); |
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3069 const char *avcodec_get_pix_fmt_name(enum PixelFormat pix_fmt); |
2270 | 3070 void avcodec_set_dimensions(AVCodecContext *s, int width, int height); |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3071 |
11059
e1bc53867092
Implement av_get_pix_fmt(), and deprecate avcodec_get_pix_fmt().
stefano
parents:
11055
diff
changeset
|
3072 #if LIBAVCODEC_VERSION_MAJOR < 53 |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3073 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3074 * Returns the pixel format corresponding to the name name. |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3075 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3076 * If there is no pixel format with name name, then looks for a |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3077 * pixel format with the name corresponding to the native endian |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3078 * format of name. |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3079 * For example in a little-endian system, first looks for "gray16", |
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3080 * then for "gray16le". |
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3081 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3082 * Finally if no pixel format has been found, returns PIX_FMT_NONE. |
11059
e1bc53867092
Implement av_get_pix_fmt(), and deprecate avcodec_get_pix_fmt().
stefano
parents:
11055
diff
changeset
|
3083 * |
e1bc53867092
Implement av_get_pix_fmt(), and deprecate avcodec_get_pix_fmt().
stefano
parents:
11055
diff
changeset
|
3084 * @deprecated Deprecated in favor of av_get_pix_fmt(). |
9222
e314914641bc
Extend the behavior of avcodec_get_pix_fmt(), if it cannot find a
stefano
parents:
9221
diff
changeset
|
3085 */ |
11059
e1bc53867092
Implement av_get_pix_fmt(), and deprecate avcodec_get_pix_fmt().
stefano
parents:
11055
diff
changeset
|
3086 attribute_deprecated enum PixelFormat avcodec_get_pix_fmt(const char* name); |
e1bc53867092
Implement av_get_pix_fmt(), and deprecate avcodec_get_pix_fmt().
stefano
parents:
11055
diff
changeset
|
3087 #endif |
10765 | 3088 |
3089 /** | |
3090 * Returns a value representing the fourCC code associated to the | |
3091 * pixel format pix_fmt, or 0 if no associated fourCC code can be | |
3092 * found. | |
3093 */ | |
3094 unsigned int avcodec_pix_fmt_to_codec_tag(enum PixelFormat pix_fmt); | |
49 | 3095 |
11809
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3096 /** |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3097 * Puts a string representing the codec tag codec_tag in buf. |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3098 * |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3099 * @param buf_size size in bytes of buf |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3100 * @return the length of the string that would have been generated if |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3101 * enough space had been available, excluding the trailing null |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3102 */ |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3103 size_t av_get_codec_tag_string(char *buf, size_t buf_size, unsigned int codec_tag); |
867d82f512df
Implement av_get_codec_tag_string() and use it in ffprobe.
stefano
parents:
11801
diff
changeset
|
3104 |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3105 #define FF_LOSS_RESOLUTION 0x0001 /**< loss due to resolution change */ |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3106 #define FF_LOSS_DEPTH 0x0002 /**< loss due to color depth change */ |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3107 #define FF_LOSS_COLORSPACE 0x0004 /**< loss due to color space conversion */ |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3108 #define FF_LOSS_ALPHA 0x0008 /**< loss of alpha bits */ |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3109 #define FF_LOSS_COLORQUANT 0x0010 /**< loss due to color quantization */ |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3110 #define FF_LOSS_CHROMA 0x0020 /**< loss of chroma (e.g. RGB to gray conversion) */ |
1200
b448d7c17215
new YUV formats for correct JPEG YUV support - added automatic pixel format conversion guessing (minimize loss and size)
bellard
parents:
1196
diff
changeset
|
3111 |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3112 /** |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3113 * Computes what kind of losses will occur when converting from one specific |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3114 * pixel format to another. |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3115 * When converting from one pixel format to another, information loss may occur. |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3116 * For example, when converting from RGB24 to GRAY, the color information will |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3117 * be lost. Similarly, other losses occur when converting from some formats to |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3118 * other formats. These losses can involve loss of chroma, but also loss of |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3119 * resolution, loss of color depth, loss due to the color space conversion, loss |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3120 * of the alpha bits or loss due to color quantization. |
4794 | 3121 * avcodec_get_fix_fmt_loss() informs you about the various types of losses |
3122 * which will occur when converting from one pixel format to another. | |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3123 * |
4794 | 3124 * @param[in] dst_pix_fmt destination pixel format |
3125 * @param[in] src_pix_fmt source pixel format | |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3126 * @param[in] has_alpha Whether the source pixel format alpha channel is used. |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3127 * @return Combination of flags informing you what kind of losses will occur. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3128 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3129 int avcodec_get_pix_fmt_loss(enum PixelFormat dst_pix_fmt, enum PixelFormat src_pix_fmt, |
1200
b448d7c17215
new YUV formats for correct JPEG YUV support - added automatic pixel format conversion guessing (minimize loss and size)
bellard
parents:
1196
diff
changeset
|
3130 int has_alpha); |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3131 |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3132 /** |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3133 * Finds the best pixel format to convert to given a certain source pixel |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3134 * format. When converting from one pixel format to another, information loss |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3135 * may occur. For example, when converting from RGB24 to GRAY, the color |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3136 * information will be lost. Similarly, other losses occur when converting from |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3137 * some formats to other formats. avcodec_find_best_pix_fmt() searches which of |
4794 | 3138 * the given pixel formats should be used to suffer the least amount of loss. |
3139 * The pixel formats from which it chooses one, are determined by the | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3140 * pix_fmt_mask parameter. |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3141 * |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3142 * @code |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3143 * src_pix_fmt = PIX_FMT_YUV420P; |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3144 * pix_fmt_mask = (1 << PIX_FMT_YUV422P) || (1 << PIX_FMT_RGB24); |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3145 * dst_pix_fmt = avcodec_find_best_pix_fmt(pix_fmt_mask, src_pix_fmt, alpha, &loss); |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3146 * @endcode |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3147 * |
4794 | 3148 * @param[in] pix_fmt_mask bitmask determining which pixel format to choose from |
3149 * @param[in] src_pix_fmt source pixel format | |
4612
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3150 * @param[in] has_alpha Whether the source pixel format alpha channel is used. |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3151 * @param[out] loss_ptr Combination of flags informing you what kind of losses will occur. |
5f3e6c177bac
Add documentation to some avcodec.h's pix_fmt related functions and defines.
takis
parents:
4610
diff
changeset
|
3152 * @return The best pixel format to convert to or -1 if none was found. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3153 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3154 enum PixelFormat avcodec_find_best_pix_fmt(int64_t pix_fmt_mask, enum PixelFormat src_pix_fmt, |
1200
b448d7c17215
new YUV formats for correct JPEG YUV support - added automatic pixel format conversion guessing (minimize loss and size)
bellard
parents:
1196
diff
changeset
|
3155 int has_alpha, int *loss_ptr); |
b448d7c17215
new YUV formats for correct JPEG YUV support - added automatic pixel format conversion guessing (minimize loss and size)
bellard
parents:
1196
diff
changeset
|
3156 |
5084
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3157 |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3158 /** |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3159 * Print in buf the string corresponding to the pixel format with |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3160 * number pix_fmt, or an header if pix_fmt is negative. |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3161 * |
5922
b731c1f3d806
Attribute for specifying direction should come right after @param.
takis
parents:
5887
diff
changeset
|
3162 * @param[in] buf the buffer where to write the string |
b731c1f3d806
Attribute for specifying direction should come right after @param.
takis
parents:
5887
diff
changeset
|
3163 * @param[in] buf_size the size of buf |
b731c1f3d806
Attribute for specifying direction should come right after @param.
takis
parents:
5887
diff
changeset
|
3164 * @param[in] pix_fmt the number of the pixel format to print the corresponding info string, or |
5084
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3165 * a negative value to print the corresponding header. |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3166 * Meaningful values for obtaining a pixel format info vary from 0 to PIX_FMT_NB -1. |
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3167 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3168 void avcodec_pix_fmt_string (char *buf, int buf_size, enum PixelFormat pix_fmt); |
5084
9930b7031cb2
Add support for listing the supported pixel formats using the option
benoit
parents:
5041
diff
changeset
|
3169 |
1208 | 3170 #define FF_ALPHA_TRANSP 0x0001 /* image has some totally transparent pixels */ |
3171 #define FF_ALPHA_SEMI_TRANSP 0x0002 /* image has some transparent pixels */ | |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3172 |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3173 /** |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3174 * Tell if an image really has transparent alpha values. |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3175 * @return ored mask of FF_ALPHA_xxx constants |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3176 */ |
1488
766a2f4edbea
avcodec const correctness patch by (Drew Hess <dhess at ilm dot com>)
michaelni
parents:
1486
diff
changeset
|
3177 int img_get_alpha_info(const AVPicture *src, |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3178 enum PixelFormat pix_fmt, int width, int height); |
1208 | 3179 |
49 | 3180 /* deinterlace a picture */ |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3181 /* deinterlace - if not supported return -1 */ |
1488
766a2f4edbea
avcodec const correctness patch by (Drew Hess <dhess at ilm dot com>)
michaelni
parents:
1486
diff
changeset
|
3182 int avpicture_deinterlace(AVPicture *dst, const AVPicture *src, |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3183 enum PixelFormat pix_fmt, int width, int height); |
0 | 3184 |
3185 /* external high level API */ | |
3186 | |
8921 | 3187 /** |
3188 * If c is NULL, returns the first registered codec, | |
8933
678fc8612787
Improve grammar: "X next after Y" -> "next X after Y".
stefano
parents:
8921
diff
changeset
|
3189 * if c is non-NULL, returns the next registered codec after c, |
8921 | 3190 * or NULL if c is the last one. |
3191 */ | |
6011 | 3192 AVCodec *av_codec_next(AVCodec *c); |
0 | 3193 |
7521 | 3194 /** |
3195 * Returns the LIBAVCODEC_VERSION_INT constant. | |
3196 */ | |
399 | 3197 unsigned avcodec_version(void); |
7521 | 3198 |
4566 | 3199 /** |
10536
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3200 * Returns the libavcodec build-time configuration. |
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3201 */ |
10764
4546d91de818
Prefer "*FUNC_NAME(" over "* FUNC_NAME(" for XXX_configuration() and
stefano
parents:
10707
diff
changeset
|
3202 const char *avcodec_configuration(void); |
10536
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3203 |
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3204 /** |
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3205 * Returns the libavcodec license. |
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3206 */ |
10764
4546d91de818
Prefer "*FUNC_NAME(" over "* FUNC_NAME(" for XXX_configuration() and
stefano
parents:
10707
diff
changeset
|
3207 const char *avcodec_license(void); |
10536
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3208 |
046dcf7aa19c
Add functions to return library license and library configuration.
diego
parents:
10527
diff
changeset
|
3209 /** |
4566 | 3210 * Initializes libavcodec. |
3211 * | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3212 * @warning This function must be called before any other libavcodec |
4566 | 3213 * function. |
3214 */ | |
0 | 3215 void avcodec_init(void); |
3216 | |
8752
7fd1422a8703
Drop the deprecated function register_avcodec() at the next major
stefano
parents:
8751
diff
changeset
|
3217 #if LIBAVCODEC_VERSION_MAJOR < 53 |
8326 | 3218 /** |
8750
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3219 * @deprecated Deprecated in favor of avcodec_register(). |
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3220 */ |
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3221 attribute_deprecated void register_avcodec(AVCodec *codec); |
8752
7fd1422a8703
Drop the deprecated function register_avcodec() at the next major
stefano
parents:
8751
diff
changeset
|
3222 #endif |
8750
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3223 |
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3224 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3225 * Register the codec codec and initialize libavcodec. |
8326 | 3226 * |
3227 * @see avcodec_init() | |
3228 */ | |
8750
2528b6a2b5d3
Rename register_avcodec() as avcodec_register() and deprecate the old
stefano
parents:
8747
diff
changeset
|
3229 void avcodec_register(AVCodec *codec); |
4566 | 3230 |
3231 /** | |
5808
b809aff51f19
Specify in documentation that avcodec_find_(en|de)coder* only searches for
ramiro
parents:
5790
diff
changeset
|
3232 * Finds a registered encoder with a matching codec ID. |
4566 | 3233 * |
4794 | 3234 * @param id CodecID of the requested encoder |
4566 | 3235 * @return An encoder if one was found, NULL otherwise. |
3236 */ | |
0 | 3237 AVCodec *avcodec_find_encoder(enum CodecID id); |
4566 | 3238 |
3239 /** | |
5808
b809aff51f19
Specify in documentation that avcodec_find_(en|de)coder* only searches for
ramiro
parents:
5790
diff
changeset
|
3240 * Finds a registered encoder with the specified name. |
4566 | 3241 * |
4794 | 3242 * @param name name of the requested encoder |
4566 | 3243 * @return An encoder if one was found, NULL otherwise. |
3244 */ | |
177 | 3245 AVCodec *avcodec_find_encoder_by_name(const char *name); |
4566 | 3246 |
3247 /** | |
5808
b809aff51f19
Specify in documentation that avcodec_find_(en|de)coder* only searches for
ramiro
parents:
5790
diff
changeset
|
3248 * Finds a registered decoder with a matching codec ID. |
4566 | 3249 * |
4794 | 3250 * @param id CodecID of the requested decoder |
4566 | 3251 * @return A decoder if one was found, NULL otherwise. |
3252 */ | |
0 | 3253 AVCodec *avcodec_find_decoder(enum CodecID id); |
4566 | 3254 |
3255 /** | |
5808
b809aff51f19
Specify in documentation that avcodec_find_(en|de)coder* only searches for
ramiro
parents:
5790
diff
changeset
|
3256 * Finds a registered decoder with the specified name. |
4566 | 3257 * |
4794 | 3258 * @param name name of the requested decoder |
4566 | 3259 * @return A decoder if one was found, NULL otherwise. |
3260 */ | |
0 | 3261 AVCodec *avcodec_find_decoder_by_name(const char *name); |
3262 void avcodec_string(char *buf, int buf_size, AVCodecContext *enc, int encode); | |
3263 | |
4566 | 3264 /** |
3265 * Sets the fields of the given AVCodecContext to default values. | |
3266 * | |
3267 * @param s The AVCodecContext of which the fields should be set to default values. | |
3268 */ | |
903 | 3269 void avcodec_get_context_defaults(AVCodecContext *s); |
4566 | 3270 |
4630
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3271 /** THIS FUNCTION IS NOT YET PART OF THE PUBLIC API! |
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3272 * we WILL change its arguments and name a few times! */ |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
3273 void avcodec_get_context_defaults2(AVCodecContext *s, enum AVMediaType); |
4630
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3274 |
4566 | 3275 /** |
3276 * Allocates an AVCodecContext and sets its fields to default values. The | |
3277 * resulting struct can be deallocated by simply calling av_free(). | |
3278 * | |
3279 * @return An AVCodecContext filled with default values or NULL on failure. | |
3280 * @see avcodec_get_context_defaults | |
3281 */ | |
703 | 3282 AVCodecContext *avcodec_alloc_context(void); |
4566 | 3283 |
4630
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3284 /** THIS FUNCTION IS NOT YET PART OF THE PUBLIC API! |
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3285 * we WILL change its arguments and name a few times! */ |
11560
8a4984c5cacc
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
11559
diff
changeset
|
3286 AVCodecContext *avcodec_alloc_context2(enum AVMediaType); |
4630
1416371d4a6c
add avcodec_get_context_defaults2() / avcodec_alloc_context2() which take CodecType as an additional parameter
michael
parents:
4624
diff
changeset
|
3287 |
4566 | 3288 /** |
11565 | 3289 * Copy the settings of the source AVCodecContext into the destination |
3290 * AVCodecContext. The resulting destination codec context will be | |
3291 * unopened, i.e. you are required to call avcodec_open() before you | |
3292 * can use this AVCodecContext to decode/encode video/audio data. | |
3293 * | |
3294 * @param dest target codec context, should be initialized with | |
3295 * avcodec_alloc_context(), but otherwise uninitialized | |
3296 * @param src source codec context | |
3297 * @return AVERROR() on error (e.g. memory allocation error), 0 on success | |
3298 */ | |
3299 int avcodec_copy_context(AVCodecContext *dest, const AVCodecContext *src); | |
3300 | |
3301 /** | |
4566 | 3302 * Sets the fields of the given AVFrame to default values. |
3303 * | |
3304 * @param pic The AVFrame of which the fields should be set to default values. | |
3305 */ | |
1904 | 3306 void avcodec_get_frame_defaults(AVFrame *pic); |
4566 | 3307 |
3308 /** | |
3309 * Allocates an AVFrame and sets its fields to default values. The resulting | |
3310 * struct can be deallocated by simply calling av_free(). | |
3311 * | |
3312 * @return An AVFrame filled with default values or NULL on failure. | |
3313 * @see avcodec_get_frame_defaults | |
3314 */ | |
925 | 3315 AVFrame *avcodec_alloc_frame(void); |
903 | 3316 |
925 | 3317 int avcodec_default_get_buffer(AVCodecContext *s, AVFrame *pic); |
3318 void avcodec_default_release_buffer(AVCodecContext *s, AVFrame *pic); | |
2026 | 3319 int avcodec_default_reget_buffer(AVCodecContext *s, AVFrame *pic); |
11567
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3320 |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3321 /** |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3322 * Returns the amount of padding in pixels which the get_buffer callback must |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3323 * provide around the edge of the image for codecs which do not have the |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3324 * CODEC_FLAG_EMU_EDGE flag. |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3325 * |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3326 * @return Required padding in pixels. |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3327 */ |
1025297f5624
Add function to export EDGE_WIDTH from libavcodec.
koorogi
parents:
11566
diff
changeset
|
3328 unsigned avcodec_get_edge_width(void); |
11311
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3329 /** |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3330 * Modifies width and height values so that they will result in a memory |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3331 * buffer that is acceptable for the codec if you do not use any horizontal |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3332 * padding. |
11754
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3333 * |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3334 * May only be used if a codec with CODEC_CAP_DR1 has been opened. |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3335 * If CODEC_FLAG_EMU_EDGE is not set, the dimensions must have been increased |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3336 * according to avcodec_get_edge_width() before. |
11311
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3337 */ |
2026 | 3338 void avcodec_align_dimensions(AVCodecContext *s, int *width, int *height); |
11311
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3339 /** |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3340 * Modifies width and height values so that they will result in a memory |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3341 * buffer that is acceptable for the codec if you also ensure that all |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3342 * line sizes are a multiple of the respective linesize_align[i]. |
11754
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3343 * |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3344 * May only be used if a codec with CODEC_CAP_DR1 has been opened. |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3345 * If CODEC_FLAG_EMU_EDGE is not set, the dimensions must have been increased |
0ec1a0299e2d
Document CODEC_FLAG_EMU_EDGE and avcodec_align_dimensions interaction.
reimar
parents:
11751
diff
changeset
|
3346 * according to avcodec_get_edge_width() before. |
11311
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3347 */ |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3348 void avcodec_align_dimensions2(AVCodecContext *s, int *width, int *height, |
ee2e050815be
Fix avcodec_align_dimensions to return values suitably aligned for FLV decoding
reimar
parents:
11299
diff
changeset
|
3349 int linesize_align[4]); |
4566 | 3350 |
3351 /** | |
3352 * Checks if the given dimension of a picture is valid, meaning that all | |
3353 * bytes of the picture can be addressed with a signed int. | |
3354 * | |
3355 * @param[in] w Width of the picture. | |
3356 * @param[in] h Height of the picture. | |
3357 * @return Zero if valid, a negative value if invalid. | |
3358 */ | |
2422 | 3359 int avcodec_check_dimensions(void *av_log_ctx, unsigned int w, unsigned int h); |
2026 | 3360 enum PixelFormat avcodec_default_get_format(struct AVCodecContext *s, const enum PixelFormat * fmt); |
903 | 3361 |
1832 | 3362 int avcodec_thread_init(AVCodecContext *s, int thread_count); |
3363 void avcodec_thread_free(AVCodecContext *s); | |
8129
a9734fe0811e
Making it easier to send arbitrary structures as work orders to MT workers
romansh
parents:
8119
diff
changeset
|
3364 int avcodec_default_execute(AVCodecContext *c, int (*func)(AVCodecContext *c2, void *arg2),void *arg, int *ret, int count, int size); |
10386
98501365c3aa
Add an execute2 function that is more flexible and allows to use parallel
reimar
parents:
10318
diff
changeset
|
3365 int avcodec_default_execute2(AVCodecContext *c, int (*func)(AVCodecContext *c2, void *arg2, int, int),void *arg, int *ret, int count); |
1799 | 3366 //FIXME func typedef |
3367 | |
1368 | 3368 /** |
4566 | 3369 * Initializes the AVCodecContext to use the given AVCodec. Prior to using this |
3370 * function the context has to be allocated. | |
3371 * | |
3372 * The functions avcodec_find_decoder_by_name(), avcodec_find_encoder_by_name(), | |
3373 * avcodec_find_decoder() and avcodec_find_encoder() provide an easy way for | |
3374 * retrieving a codec. | |
3375 * | |
4794 | 3376 * @warning This function is not thread safe! |
4566 | 3377 * |
3378 * @code | |
5137 | 3379 * avcodec_register_all(); |
4566 | 3380 * codec = avcodec_find_decoder(CODEC_ID_H264); |
3381 * if (!codec) | |
3382 * exit(1); | |
3383 * | |
3384 * context = avcodec_alloc_context(); | |
3385 * | |
3386 * if (avcodec_open(context, codec) < 0) | |
3387 * exit(1); | |
3388 * @endcode | |
3389 * | |
4794 | 3390 * @param avctx The context which will be set up to use the given codec. |
4566 | 3391 * @param codec The codec to use within the context. |
4794 | 3392 * @return zero on success, a negative value on error |
4566 | 3393 * @see avcodec_alloc_context, avcodec_find_decoder, avcodec_find_encoder |
1368 | 3394 */ |
0 | 3395 int avcodec_open(AVCodecContext *avctx, AVCodec *codec); |
1368 | 3396 |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3397 #if LIBAVCODEC_VERSION_MAJOR < 53 |
4566 | 3398 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3399 * Decodes an audio frame from buf into samples. |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3400 * Wrapper function which calls avcodec_decode_audio3. |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3401 * |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3402 * @deprecated Use avcodec_decode_audio3 instead. |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3403 * @param avctx the codec context |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3404 * @param[out] samples the output buffer |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3405 * @param[in,out] frame_size_ptr the output buffer size in bytes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3406 * @param[in] buf the input buffer |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3407 * @param[in] buf_size the input buffer size in bytes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3408 * @return On error a negative value is returned, otherwise the number of bytes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3409 * used or zero if no frame could be decompressed. |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3410 */ |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3411 attribute_deprecated int avcodec_decode_audio2(AVCodecContext *avctx, int16_t *samples, |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3412 int *frame_size_ptr, |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3413 const uint8_t *buf, int buf_size); |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3414 #endif |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3415 |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3416 /** |
9571
e54c83a838a9
Cleanup first paragraph of doxy of avcodec_decode_audio3().
michael
parents:
9570
diff
changeset
|
3417 * Decodes the audio frame of size avpkt->size from avpkt->data into samples. |
e54c83a838a9
Cleanup first paragraph of doxy of avcodec_decode_audio3().
michael
parents:
9570
diff
changeset
|
3418 * Some decoders may support multiple frames in a single AVPacket, such |
10389 | 3419 * decoders would then just decode the first frame. In this case, |
3420 * avcodec_decode_audio3 has to be called again with an AVPacket that contains | |
3421 * the remaining data in order to decode the second frame etc. | |
9571
e54c83a838a9
Cleanup first paragraph of doxy of avcodec_decode_audio3().
michael
parents:
9570
diff
changeset
|
3422 * If no frame |
10389 | 3423 * could be outputted, frame_size_ptr is zero. Otherwise, it is the |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3424 * decompressed frame size in bytes. |
4566 | 3425 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3426 * @warning You must set frame_size_ptr to the allocated size of the |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3427 * output buffer before calling avcodec_decode_audio3(). |
4566 | 3428 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3429 * @warning The input buffer must be FF_INPUT_BUFFER_PADDING_SIZE larger than |
4566 | 3430 * the actual read bytes because some optimized bitstream readers read 32 or 64 |
3431 * bits at once and could read over the end. | |
3660
7e1ee254a3ee
Align the input buffer in ffplay, introduce a public macro for aligned declarations
lu_zero
parents:
3618
diff
changeset
|
3432 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3433 * @warning The end of the input buffer avpkt->data should be set to 0 to ensure that |
4566 | 3434 * no overreading happens for damaged MPEG streams. |
3435 * | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3436 * @note You might have to align the input buffer avpkt->data and output buffer |
4794 | 3437 * samples. The alignment requirements depend on the CPU: On some CPUs it isn't |
4566 | 3438 * necessary at all, on others it won't work at all if not aligned and on others |
9825
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3439 * it will work but it will have an impact on performance. |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3440 * |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3441 * In practice, avpkt->data should have 4 byte alignment at minimum and |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3442 * samples should be 16 byte aligned unless the CPU doesn't need it |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3443 * (AltiVec and SSE do). |
4566 | 3444 * |
4794 | 3445 * @param avctx the codec context |
9882
7b58b1410f48
Make documentation better match the code. Now AVCodecContext.sample_fmt
vitor
parents:
9866
diff
changeset
|
3446 * @param[out] samples the output buffer, sample type in avctx->sample_fmt |
4794 | 3447 * @param[in,out] frame_size_ptr the output buffer size in bytes |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3448 * @param[in] avpkt The input AVPacket containing the input buffer. |
9785 | 3449 * You can create such packet with av_init_packet() and by then setting |
3450 * data and size, some decoders might in addition need other fields. | |
3451 * All decoders are designed to use the least fields possible though. | |
4566 | 3452 * @return On error a negative value is returned, otherwise the number of bytes |
10389 | 3453 * used or zero if no frame data was decompressed (used) from the input AVPacket. |
3660
7e1ee254a3ee
Align the input buffer in ffplay, introduce a public macro for aligned declarations
lu_zero
parents:
3618
diff
changeset
|
3454 */ |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3455 int avcodec_decode_audio3(AVCodecContext *avctx, int16_t *samples, |
0 | 3456 int *frame_size_ptr, |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3457 AVPacket *avpkt); |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3458 |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3459 #if LIBAVCODEC_VERSION_MAJOR < 53 |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3460 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3461 * Decodes a video frame from buf into picture. |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3462 * Wrapper function which calls avcodec_decode_video2. |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3463 * |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3464 * @deprecated Use avcodec_decode_video2 instead. |
9578
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3465 * @param avctx the codec context |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3466 * @param[out] picture The AVFrame in which the decoded video frame will be stored. |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3467 * @param[in] buf the input buffer |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3468 * @param[in] buf_size the size of the input buffer in bytes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3469 * @param[in,out] got_picture_ptr Zero if no frame could be decompressed, otherwise, it is nonzero. |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3470 * @return On error a negative value is returned, otherwise the number of bytes |
14b9819158a8
Revert r18700, documentation of deprecated functions might be useful for
vitor
parents:
9575
diff
changeset
|
3471 * used or zero if no frame could be decompressed. |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3472 */ |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3473 attribute_deprecated int avcodec_decode_video(AVCodecContext *avctx, AVFrame *picture, |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3474 int *got_picture_ptr, |
6318
73c09e922744
Make avcodec_decode_* functions take const input buffers.
michael
parents:
6215
diff
changeset
|
3475 const uint8_t *buf, int buf_size); |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3476 #endif |
4566 | 3477 |
3478 /** | |
9569
99b812cc77a9
Remove confusing and redundant engrish chatter from avcodec_decode_video2().
michael
parents:
9535
diff
changeset
|
3479 * Decodes the video frame of size avpkt->size from avpkt->data into picture. |
9572
b3074f49b078
Add multiframe note to avcodec_decode_video() too.
michael
parents:
9571
diff
changeset
|
3480 * Some decoders may support multiple frames in a single AVPacket, such |
b3074f49b078
Add multiframe note to avcodec_decode_video() too.
michael
parents:
9571
diff
changeset
|
3481 * decoders would then just decode the first frame. |
4566 | 3482 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3483 * @warning The input buffer must be FF_INPUT_BUFFER_PADDING_SIZE larger than |
4566 | 3484 * the actual read bytes because some optimized bitstream readers read 32 or 64 |
3485 * bits at once and could read over the end. | |
3486 * | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3487 * @warning The end of the input buffer buf should be set to 0 to ensure that |
4566 | 3488 * no overreading happens for damaged MPEG streams. |
3489 * | |
9825
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3490 * @note You might have to align the input buffer avpkt->data. |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3491 * The alignment requirements depend on the CPU: on some CPUs it isn't |
4566 | 3492 * necessary at all, on others it won't work at all if not aligned and on others |
9825
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3493 * it will work but it will have an impact on performance. |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3494 * |
37558edc9df2
clarify avcodec_decode_audio3 and avcodec_decode_video2 doxygen
bcoudurier
parents:
9822
diff
changeset
|
3495 * In practice, avpkt->data should have 4 byte alignment at minimum. |
4566 | 3496 * |
8548
3586e03586a0
Document the need of buf=NULL buf_size=0 at the end to obtain all frames.
michael
parents:
8522
diff
changeset
|
3497 * @note Some codecs have a delay between input and output, these need to be |
10686 | 3498 * fed with avpkt->data=NULL, avpkt->size=0 at the end to return the remaining frames. |
8548
3586e03586a0
Document the need of buf=NULL buf_size=0 at the end to obtain all frames.
michael
parents:
8522
diff
changeset
|
3499 * |
4794 | 3500 * @param avctx the codec context |
4566 | 3501 * @param[out] picture The AVFrame in which the decoded video frame will be stored. |
11690
56a2ead12502
Another try for fixing/improving decode_video documentation.
reimar
parents:
11689
diff
changeset
|
3502 * Use avcodec_alloc_frame to get an AVFrame, the codec will |
56a2ead12502
Another try for fixing/improving decode_video documentation.
reimar
parents:
11689
diff
changeset
|
3503 * allocate memory for the actual bitmap. |
11822
8cd526e30b06
Document the frames returned by the decoder better.
michael
parents:
11821
diff
changeset
|
3504 * with default get/release_buffer(), the decoder frees/reuses the bitmap as it sees fit. |
11823
c9ef45275db0
Clarify that get/release_buffer() overriding only works with CODEC_CAP_DR1 codecs.
michael
parents:
11822
diff
changeset
|
3505 * with overridden get/release_buffer() (needs CODEC_CAP_DR1) the user decides into what buffer the decoder |
11822
8cd526e30b06
Document the frames returned by the decoder better.
michael
parents:
11821
diff
changeset
|
3506 * decodes and the decoder tells the user once it does not need the data anymore, |
8cd526e30b06
Document the frames returned by the decoder better.
michael
parents:
11821
diff
changeset
|
3507 * the user app can at this point free/reuse/keep the memory as it sees fit. |
8cd526e30b06
Document the frames returned by the decoder better.
michael
parents:
11821
diff
changeset
|
3508 * |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3509 * @param[in] avpkt The input AVpacket containing the input buffer. |
9785 | 3510 * You can create such packet with av_init_packet() and by then setting |
3511 * data and size, some decoders might in addition need other fields like | |
11563
5111783be6ad
Replace all occurences of PKT_FLAG_KEY with AV_PKT_FLAG_KEY.
cehoyos
parents:
11561
diff
changeset
|
3512 * flags&AV_PKT_FLAG_KEY. All decoders are designed to use the least |
9785 | 3513 * fields possible. |
4794 | 3514 * @param[in,out] got_picture_ptr Zero if no frame could be decompressed, otherwise, it is nonzero. |
4566 | 3515 * @return On error a negative value is returned, otherwise the number of bytes |
3516 * used or zero if no frame could be decompressed. | |
3517 */ | |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3518 int avcodec_decode_video2(AVCodecContext *avctx, AVFrame *picture, |
0 | 3519 int *got_picture_ptr, |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3520 AVPacket *avpkt); |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3521 |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3522 #if LIBAVCODEC_VERSION_MAJOR < 53 |
4794 | 3523 /* Decode a subtitle message. Return -1 if error, otherwise return the |
3524 * number of bytes used. If no subtitle could be decompressed, | |
3525 * got_sub_ptr is zero. Otherwise, the subtitle is stored in *sub. */ | |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3526 attribute_deprecated int avcodec_decode_subtitle(AVCodecContext *avctx, AVSubtitle *sub, |
2756 | 3527 int *got_sub_ptr, |
3528 const uint8_t *buf, int buf_size); | |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3529 #endif |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3530 |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3531 /** |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3532 * Decodes a subtitle message. |
9573
c939417a3a39
Negative is error not -1, corrected in the doxy for avcodec_decode_subtitle2().
michael
parents:
9572
diff
changeset
|
3533 * Returns a negative value on error, otherwise returns the number of bytes used. |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3534 * If no subtitle could be decompressed, got_sub_ptr is zero. |
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3535 * Otherwise, the subtitle is stored in *sub. |
9355
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3536 * |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3537 * @param avctx the codec context |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3538 * @param[out] sub The AVSubtitle in which the decoded subtitle will be stored. |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3539 * @param[in,out] got_sub_ptr Zero if no subtitle could be decompressed, otherwise, it is nonzero. |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3540 * @param[in] avpkt The input AVPacket containing the input buffer. |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3541 */ |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3542 int avcodec_decode_subtitle2(AVCodecContext *avctx, AVSubtitle *sub, |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3543 int *got_sub_ptr, |
54bc8a2727b0
Implement avcodec_decode_video2(), _audio3() and _subtitle2() which takes an
rbultje
parents:
9354
diff
changeset
|
3544 AVPacket *avpkt); |
2967 | 3545 int avcodec_parse_frame(AVCodecContext *avctx, uint8_t **pdata, |
581
8adda0af04e2
added proposed API for parse_only mode to extract compressed frames from compressed streams
bellard
parents:
573
diff
changeset
|
3546 int *data_size_ptr, |
1064 | 3547 uint8_t *buf, int buf_size); |
4566 | 3548 |
3549 /** | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3550 * Encodes an audio frame from samples into buf. |
4566 | 3551 * |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3552 * @note The output buffer should be at least FF_MIN_BUFFER_SIZE bytes large. |
9409
e6ade5c8a750
Fix documentation for avcodec_encode_audio(), in the case of PCM audio
stefano
parents:
9394
diff
changeset
|
3553 * However, for PCM audio the user will know how much space is needed |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3554 * because it depends on the value passed in buf_size as described |
9409
e6ade5c8a750
Fix documentation for avcodec_encode_audio(), in the case of PCM audio
stefano
parents:
9394
diff
changeset
|
3555 * below. In that case a lower value can be used. |
4566 | 3556 * |
4794 | 3557 * @param avctx the codec context |
3558 * @param[out] buf the output buffer | |
3559 * @param[in] buf_size the output buffer size | |
3560 * @param[in] samples the input buffer containing the samples | |
5953 | 3561 * The number of samples read from this buffer is frame_size*channels, |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3562 * both of which are defined in avctx. |
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3563 * For PCM audio the number of samples read from samples is equal to |
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3564 * buf_size * input_sample_size / output_sample_size. |
5961 | 3565 * @return On error a negative value is returned, on success zero or the number |
5953 | 3566 * of bytes used to encode the data read from the input buffer. |
4566 | 3567 */ |
2967 | 3568 int avcodec_encode_audio(AVCodecContext *avctx, uint8_t *buf, int buf_size, |
0 | 3569 const short *samples); |
4566 | 3570 |
3571 /** | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3572 * Encodes a video frame from pict into buf. |
9575
cb2eaa883d4f
Remove useless and outright wrong chatter from avcodec_encode_video().
michael
parents:
9574
diff
changeset
|
3573 * The input picture should be |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3574 * stored using a specific format, namely avctx.pix_fmt. |
4566 | 3575 * |
4794 | 3576 * @param avctx the codec context |
3577 * @param[out] buf the output buffer for the bitstream of encoded frame | |
3578 * @param[in] buf_size the size of the output buffer in bytes | |
3579 * @param[in] pict the input picture to encode | |
4566 | 3580 * @return On error a negative value is returned, on success zero or the number |
8700
ebb66d91b011
Fix documentation of the return value of avcodec_encode_video().
michael
parents:
8667
diff
changeset
|
3581 * of bytes used from the output buffer. |
4566 | 3582 */ |
2967 | 3583 int avcodec_encode_video(AVCodecContext *avctx, uint8_t *buf, int buf_size, |
925 | 3584 const AVFrame *pict); |
2967 | 3585 int avcodec_encode_subtitle(AVCodecContext *avctx, uint8_t *buf, int buf_size, |
2756 | 3586 const AVSubtitle *sub); |
0 | 3587 |
3588 int avcodec_close(AVCodecContext *avctx); | |
3589 | |
8328
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3590 /** |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3591 * Register all the codecs, parsers and bitstream filters which were enabled at |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3592 * configuration time. If you do not call this function you can select exactly |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3593 * which formats you want to support, by using the individual registration |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3594 * functions. |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3595 * |
8751
303929f52007
Replace the calls to the deprecated function register_avcodec() with
stefano
parents:
8750
diff
changeset
|
3596 * @see avcodec_register |
8328
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3597 * @see av_register_codec_parser |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3598 * @see av_register_bitstream_filter |
2e654989814e
Move documentation of avcodec_register_all() from allcodecs.c to
stefano
parents:
8327
diff
changeset
|
3599 */ |
0 | 3600 void avcodec_register_all(void); |
92 | 3601 |
4567
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3602 /** |
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3603 * Flush buffers, should be called when seeking or when switching to a different stream. |
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3604 */ |
341 | 3605 void avcodec_flush_buffers(AVCodecContext *avctx); |
3606 | |
2522
e25782262d7d
kill warnings patch by (M«©ns Rullg«©rd <mru inprovide com>)
michael
parents:
2520
diff
changeset
|
3607 void avcodec_default_free_buffers(AVCodecContext *s); |
e25782262d7d
kill warnings patch by (M«©ns Rullg«©rd <mru inprovide com>)
michael
parents:
2520
diff
changeset
|
3608 |
4559 | 3609 /* misc useful functions */ |
1264 | 3610 |
3611 /** | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3612 * Returns a single letter to describe the given picture type pict_type. |
4569
dcf43f64d80d
Doxygenize the comments for the av_get_pict_type_char() function.
takis
parents:
4568
diff
changeset
|
3613 * |
4794 | 3614 * @param[in] pict_type the picture type |
4569
dcf43f64d80d
Doxygenize the comments for the av_get_pict_type_char() function.
takis
parents:
4568
diff
changeset
|
3615 * @return A single character representing the picture type. |
1264 | 3616 */ |
3617 char av_get_pict_type_char(int pict_type); | |
3618 | |
3433 | 3619 /** |
4570
58be423405db
Doxygenize the comments for the av_get_bits_per_sample() function.
takis
parents:
4569
diff
changeset
|
3620 * Returns codec bits per sample. |
58be423405db
Doxygenize the comments for the av_get_bits_per_sample() function.
takis
parents:
4569
diff
changeset
|
3621 * |
4794 | 3622 * @param[in] codec_id the codec |
4570
58be423405db
Doxygenize the comments for the av_get_bits_per_sample() function.
takis
parents:
4569
diff
changeset
|
3623 * @return Number of bits per sample or zero if unknown for the given codec. |
3433 | 3624 */ |
3625 int av_get_bits_per_sample(enum CodecID codec_id); | |
2801 | 3626 |
5537 | 3627 /** |
3628 * Returns sample format bits per sample. | |
3629 * | |
3630 * @param[in] sample_fmt the sample format | |
3631 * @return Number of bits per sample or zero if unknown for the given sample format. | |
3632 */ | |
3633 int av_get_bits_per_sample_format(enum SampleFormat sample_fmt); | |
3634 | |
1613 | 3635 /* frame parsing */ |
3636 typedef struct AVCodecParserContext { | |
3637 void *priv_data; | |
3638 struct AVCodecParser *parser; | |
3639 int64_t frame_offset; /* offset of the current frame */ | |
2967 | 3640 int64_t cur_offset; /* current offset |
1613 | 3641 (incremented by each av_parser_parse()) */ |
6979 | 3642 int64_t next_frame_offset; /* offset of the next frame */ |
1613 | 3643 /* video info */ |
4794 | 3644 int pict_type; /* XXX: Put it back in AVCodecContext. */ |
9000
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3645 /** |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3646 * This field is used for proper frame duration computation in lavf. |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3647 * It signals, how much longer the frame duration of the current frame |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3648 * is compared to normal frame duration. |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3649 * |
9034
96731d42ca82
Change duration computation to use time_base instead of TB/2.
cehoyos
parents:
9012
diff
changeset
|
3650 * frame_duration = (1 + repeat_pict) * time_base |
9000
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3651 * |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3652 * It is used by codecs like H.264 to display telecined material. |
78afc2990d00
Use context variable repeat_pict for frame duration computation and
cehoyos
parents:
8989
diff
changeset
|
3653 */ |
4794 | 3654 int repeat_pict; /* XXX: Put it back in AVCodecContext. */ |
1696 | 3655 int64_t pts; /* pts of the current frame */ |
3656 int64_t dts; /* dts of the current frame */ | |
3657 | |
3658 /* private data */ | |
3659 int64_t last_pts; | |
3660 int64_t last_dts; | |
2030 | 3661 int fetch_timestamp; |
1696 | 3662 |
3663 #define AV_PARSER_PTS_NB 4 | |
3664 int cur_frame_start_index; | |
3665 int64_t cur_frame_offset[AV_PARSER_PTS_NB]; | |
3666 int64_t cur_frame_pts[AV_PARSER_PTS_NB]; | |
3667 int64_t cur_frame_dts[AV_PARSER_PTS_NB]; | |
2967 | 3668 |
2837 | 3669 int flags; |
3670 #define PARSER_FLAG_COMPLETE_FRAMES 0x0001 | |
11770
6d58a4f5e455
Add an AVSTREAM_PARSE_FULL_ONCE parsing mode to parse headers and combine packets once and only once.
alexc
parents:
11756
diff
changeset
|
3671 #define PARSER_FLAG_ONCE 0x0002 |
4846 | 3672 |
3673 int64_t offset; ///< byte offset from starting packet start | |
6987
2dde03056bd6
Move new field to the end to avoid ABI breakage, I thought this struct
michael
parents:
6979
diff
changeset
|
3674 int64_t cur_frame_end[AV_PARSER_PTS_NB]; |
8973
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3675 |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3676 /*! |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3677 * Set by parser to 1 for key frames and 0 for non-key frames. |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3678 * It is initialized to -1, so if the parser doesn't set this flag, |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3679 * old-style fallback using FF_I_TYPE picture type as key frames |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3680 * will be used. |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3681 */ |
34f2c7189710
Add key_frame to AVCodecParserContext, used in libavformat.
cehoyos
parents:
8933
diff
changeset
|
3682 int key_frame; |
8989 | 3683 |
3684 /** | |
3685 * Time difference in stream time base units from the pts of this | |
3686 * packet to the point at which the output from the decoder has converged | |
3687 * independent from the availability of previous frames. That is, the | |
3688 * frames are virtually identical no matter if decoding started from | |
3689 * the very first frame or from this keyframe. | |
3690 * Is AV_NOPTS_VALUE if unknown. | |
3691 * This field is not the display duration of the current frame. | |
3692 * | |
3693 * The purpose of this field is to allow seeking in streams that have no | |
3694 * keyframes in the conventional sense. It corresponds to the | |
3695 * recovery point SEI in H.264 and match_time_delta in NUT. It is also | |
3696 * essential for some types of subtitle streams to ensure that all | |
3697 * subtitles are correctly displayed after seeking. | |
3698 */ | |
3699 int64_t convergence_duration; | |
9038
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3700 |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3701 // Timestamp generation support: |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3702 /** |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3703 * Synchronization point for start of timestamp generation. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3704 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3705 * Set to >0 for sync point, 0 for no sync point and <0 for undefined |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3706 * (default). |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3707 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3708 * For example, this corresponds to presence of H.264 buffering period |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3709 * SEI message. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3710 */ |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3711 int dts_sync_point; |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3712 |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3713 /** |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3714 * Offset of the current timestamp against last timestamp sync point in |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3715 * units of AVCodecContext.time_base. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3716 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3717 * Set to INT_MIN when dts_sync_point unused. Otherwise, it must |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3718 * contain a valid timestamp offset. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3719 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3720 * Note that the timestamp of sync point has usually a nonzero |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3721 * dts_ref_dts_delta, which refers to the previous sync point. Offset of |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3722 * the next frame after timestamp sync point will be usually 1. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3723 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3724 * For example, this corresponds to H.264 cpb_removal_delay. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3725 */ |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3726 int dts_ref_dts_delta; |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3727 |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3728 /** |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3729 * Presentation delay of current frame in units of AVCodecContext.time_base. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3730 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3731 * Set to INT_MIN when dts_sync_point unused. Otherwise, it must |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3732 * contain valid non-negative timestamp delta (presentation time of a frame |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3733 * must not lie in the past). |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3734 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3735 * This delay represents the difference between decoding and presentation |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3736 * time of the frame. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3737 * |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3738 * For example, this corresponds to H.264 dpb_output_delay. |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3739 */ |
d4c12f2d226b
Add timestamp computation if values are exported by decoder.
cehoyos
parents:
9034
diff
changeset
|
3740 int pts_dts_delta; |
9140 | 3741 |
3742 /** | |
3743 * Position of the packet in file. | |
3744 * | |
3745 * Analogous to cur_frame_pts/dts | |
3746 */ | |
3747 int64_t cur_frame_pos[AV_PARSER_PTS_NB]; | |
3748 | |
3749 /** | |
3750 * Byte position of currently parsed frame in stream. | |
3751 */ | |
3752 int64_t pos; | |
3753 | |
3754 /** | |
3755 * Previous frame byte position. | |
3756 */ | |
3757 int64_t last_pos; | |
1613 | 3758 } AVCodecParserContext; |
3759 | |
3760 typedef struct AVCodecParser { | |
2348 | 3761 int codec_ids[5]; /* several codec IDs are permitted */ |
1613 | 3762 int priv_data_size; |
3763 int (*parser_init)(AVCodecParserContext *s); | |
2967 | 3764 int (*parser_parse)(AVCodecParserContext *s, |
1613 | 3765 AVCodecContext *avctx, |
4931
0d1cc37d9430
make some parser parameters const to avoid casting const to non-const
aurel
parents:
4901
diff
changeset
|
3766 const uint8_t **poutbuf, int *poutbuf_size, |
1613 | 3767 const uint8_t *buf, int buf_size); |
3768 void (*parser_close)(AVCodecParserContext *s); | |
2769
1394b45a7bf4
support changing in bitstream global headers into extradata style and back
michael
parents:
2768
diff
changeset
|
3769 int (*split)(AVCodecContext *avctx, const uint8_t *buf, int buf_size); |
1613 | 3770 struct AVCodecParser *next; |
3771 } AVCodecParser; | |
3772 | |
6011 | 3773 AVCodecParser *av_parser_next(AVCodecParser *c); |
1613 | 3774 |
3775 void av_register_codec_parser(AVCodecParser *parser); | |
3776 AVCodecParserContext *av_parser_init(int codec_id); | |
9140 | 3777 |
9218
18dffa8f2382
Remove deprecated functions and structures on next version bump.
diego
parents:
9217
diff
changeset
|
3778 #if LIBAVCODEC_VERSION_MAJOR < 53 |
9140 | 3779 attribute_deprecated |
2967 | 3780 int av_parser_parse(AVCodecParserContext *s, |
1613 | 3781 AVCodecContext *avctx, |
2967 | 3782 uint8_t **poutbuf, int *poutbuf_size, |
1696 | 3783 const uint8_t *buf, int buf_size, |
3784 int64_t pts, int64_t dts); | |
9218
18dffa8f2382
Remove deprecated functions and structures on next version bump.
diego
parents:
9217
diff
changeset
|
3785 #endif |
9140 | 3786 |
3787 /** | |
3788 * Parse a packet. | |
3789 * | |
3790 * @param s parser context. | |
3791 * @param avctx codec context. | |
3792 * @param poutbuf set to pointer to parsed buffer or NULL if not yet finished. | |
3793 * @param poutbuf_size set to size of parsed buffer or zero if not yet finished. | |
3794 * @param buf input buffer. | |
3795 * @param buf_size input length, to signal EOF, this should be 0 (so that the last frame can be output). | |
3796 * @param pts input presentation timestamp. | |
3797 * @param dts input decoding timestamp. | |
3798 * @param pos input byte position in stream. | |
3799 * @return the number of bytes of the input bitstream used. | |
3800 * | |
3801 * Example: | |
3802 * @code | |
3803 * while(in_len){ | |
3804 * len = av_parser_parse2(myparser, AVCodecContext, &data, &size, | |
3805 * in_data, in_len, | |
3806 * pts, dts, pos); | |
3807 * in_data += len; | |
3808 * in_len -= len; | |
3809 * | |
3810 * if(size) | |
3811 * decode_frame(data, size); | |
3812 * } | |
3813 * @endcode | |
3814 */ | |
3815 int av_parser_parse2(AVCodecParserContext *s, | |
3816 AVCodecContext *avctx, | |
3817 uint8_t **poutbuf, int *poutbuf_size, | |
3818 const uint8_t *buf, int buf_size, | |
3819 int64_t pts, int64_t dts, | |
3820 int64_t pos); | |
3821 | |
2769
1394b45a7bf4
support changing in bitstream global headers into extradata style and back
michael
parents:
2768
diff
changeset
|
3822 int av_parser_change(AVCodecParserContext *s, |
1394b45a7bf4
support changing in bitstream global headers into extradata style and back
michael
parents:
2768
diff
changeset
|
3823 AVCodecContext *avctx, |
2967 | 3824 uint8_t **poutbuf, int *poutbuf_size, |
2769
1394b45a7bf4
support changing in bitstream global headers into extradata style and back
michael
parents:
2768
diff
changeset
|
3825 const uint8_t *buf, int buf_size, int keyframe); |
1613 | 3826 void av_parser_close(AVCodecParserContext *s); |
3827 | |
3421
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3828 |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3829 typedef struct AVBitStreamFilterContext { |
3422 | 3830 void *priv_data; |
3421
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3831 struct AVBitStreamFilter *filter; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3832 AVCodecParserContext *parser; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3833 struct AVBitStreamFilterContext *next; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3834 } AVBitStreamFilterContext; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3835 |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3836 |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3837 typedef struct AVBitStreamFilter { |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3838 const char *name; |
3422 | 3839 int priv_data_size; |
3421
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3840 int (*filter)(AVBitStreamFilterContext *bsfc, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3841 AVCodecContext *avctx, const char *args, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3842 uint8_t **poutbuf, int *poutbuf_size, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3843 const uint8_t *buf, int buf_size, int keyframe); |
5630 | 3844 void (*close)(AVBitStreamFilterContext *bsfc); |
3421
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3845 struct AVBitStreamFilter *next; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3846 } AVBitStreamFilter; |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3847 |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3848 void av_register_bitstream_filter(AVBitStreamFilter *bsf); |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3849 AVBitStreamFilterContext *av_bitstream_filter_init(const char *name); |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3850 int av_bitstream_filter_filter(AVBitStreamFilterContext *bsfc, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3851 AVCodecContext *avctx, const char *args, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3852 uint8_t **poutbuf, int *poutbuf_size, |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3853 const uint8_t *buf, int buf_size, int keyframe); |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3854 void av_bitstream_filter_close(AVBitStreamFilterContext *bsf); |
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3855 |
6011 | 3856 AVBitStreamFilter *av_bitstream_filter_next(AVBitStreamFilter *f); |
3421
b7826511f7b6
AVBitStreamFilter (some thingy which can modify the bitstream like add or remove global headers or change the headers or ...)
michael
parents:
3392
diff
changeset
|
3857 |
492 | 3858 /* memory */ |
4567
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3859 |
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3860 /** |
4574
a9388782b9b0
Doxygenize the comments for the av_fast_realloc() function.
takis
parents:
4573
diff
changeset
|
3861 * Reallocates the given block if it is not large enough, otherwise it |
a9388782b9b0
Doxygenize the comments for the av_fast_realloc() function.
takis
parents:
4573
diff
changeset
|
3862 * does nothing. |
a9388782b9b0
Doxygenize the comments for the av_fast_realloc() function.
takis
parents:
4573
diff
changeset
|
3863 * |
a9388782b9b0
Doxygenize the comments for the av_fast_realloc() function.
takis
parents:
4573
diff
changeset
|
3864 * @see av_realloc |
4567
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3865 */ |
1058 | 3866 void *av_fast_realloc(void *ptr, unsigned int *size, unsigned int min_size); |
4567
f0138063c568
Move the Doxygen function documentation unaltered from libavcodec/utils.c to
takis
parents:
4566
diff
changeset
|
3867 |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3868 /** |
9415
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3869 * Allocates a buffer, reusing the given one if large enough. |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3870 * |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3871 * Contrary to av_fast_realloc the current buffer contents might not be |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3872 * preserved and on error the old buffer is freed, thus no special |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3873 * handling to avoid memleaks is necessary. |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3874 * |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3875 * @param ptr pointer to pointer to already allocated buffer, overwritten with pointer to new buffer |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3876 * @param size size of the buffer *ptr points to |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3877 * @param min_size minimum size of *ptr buffer after returning, *ptr will be NULL and |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3878 * *size 0 if an error occurred. |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3879 */ |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3880 void av_fast_malloc(void *ptr, unsigned int *size, unsigned int min_size); |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3881 |
141badec76fc
Add a av_fast_malloc function and replace several uses of av_fast_realloc,
reimar
parents:
9409
diff
changeset
|
3882 /** |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3883 * Copy image 'src' to 'dst'. |
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3884 */ |
4624
6a900f539e2c
Add the prefix "av_" to img_crop(), img_copy() and img_pad(), and rename "img"
takis
parents:
4623
diff
changeset
|
3885 void av_picture_copy(AVPicture *dst, const AVPicture *src, |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3886 enum PixelFormat pix_fmt, int width, int height); |
1630 | 3887 |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3888 /** |
4794 | 3889 * Crop image top and left side. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3890 */ |
4624
6a900f539e2c
Add the prefix "av_" to img_crop(), img_copy() and img_pad(), and rename "img"
takis
parents:
4623
diff
changeset
|
3891 int av_picture_crop(AVPicture *dst, const AVPicture *src, |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3892 enum PixelFormat pix_fmt, int top_band, int left_band); |
3179 | 3893 |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3894 /** |
4794 | 3895 * Pad image. |
4593
2aea8bf268d8
Move the unaltered documentation of the functions which are part of the public
takis
parents:
4588
diff
changeset
|
3896 */ |
9221
a15ec86bf752
Globally prefer enum PixelFormat over int when it makes sense.
stefano
parents:
9218
diff
changeset
|
3897 int av_picture_pad(AVPicture *dst, const AVPicture *src, int height, int width, enum PixelFormat pix_fmt, |
3257
63f61b09dcee
Baptiste COUDURIER's padding patch (reworked by me a little bit).
lucabe
parents:
3254
diff
changeset
|
3898 int padtop, int padbottom, int padleft, int padright, int *color); |
63f61b09dcee
Baptiste COUDURIER's padding patch (reworked by me a little bit).
lucabe
parents:
3254
diff
changeset
|
3899 |
11528 | 3900 /** |
3901 * Encodes extradata length to a buffer. Used by xiph codecs. | |
3902 * | |
3903 * @param s buffer to write to; must be at least (v/255+1) bytes long | |
3904 * @param v size of extradata in bytes | |
3905 * @return number of bytes written to the buffer. | |
3906 */ | |
8250 | 3907 unsigned int av_xiphlacing(unsigned char *s, unsigned int v); |
2676 | 3908 |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3909 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3910 * Parses str and put in width_ptr and height_ptr the detected values. |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3911 * |
5127 | 3912 * @return 0 in case of a successful parsing, a negative value otherwise |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3913 * @param[in] str the string to parse: it has to be a string in the format |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3914 * <width>x<height> or a valid video frame size abbreviation. |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3915 * @param[in,out] width_ptr pointer to the variable which will contain the detected |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3916 * frame width value |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3917 * @param[in,out] height_ptr pointer to the variable which will contain the detected |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3918 * frame height value |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3919 */ |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3920 int av_parse_video_frame_size(int *width_ptr, int *height_ptr, const char *str); |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3921 |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3922 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3923 * Parses str and put in frame_rate the detected values. |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3924 * |
5127 | 3925 * @return 0 in case of a successful parsing, a negative value otherwise |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3926 * @param[in] str the string to parse: it has to be a string in the format |
8883
62342da1ec78
Attempt to clarify draw_horiz_band description and fix two random typos.
diego
parents:
8882
diff
changeset
|
3927 * <frame_rate_num>/<frame_rate_den>, a float number or a valid video rate abbreviation |
5126
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3928 * @param[in,out] frame_rate pointer to the AVRational which will contain the detected |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3929 * frame rate |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3930 */ |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3931 int av_parse_video_frame_rate(AVRational *frame_rate, const char *str); |
7982b376b58a
Move the video size and rate abbreviations system from libavformat to libavcodec
benoit
parents:
5124
diff
changeset
|
3932 |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3933 /** |
9893
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3934 * Logs a generic warning message about a missing feature. This function is |
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3935 * intended to be used internally by FFmpeg (libavcodec, libavformat, etc.) |
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3936 * only, and would normally not be used by applications. |
9892
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3937 * @param[in] avc a pointer to an arbitrary struct of which the first field is |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3938 * a pointer to an AVClass struct |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3939 * @param[in] feature string containing the name of the missing feature |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3940 * @param[in] want_sample indicates if samples are wanted which exhibit this feature. |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3941 * If want_sample is non-zero, additional verbage will be added to the log |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3942 * message which tells the user how to report samples to the development |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3943 * mailing list. |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3944 */ |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3945 void av_log_missing_feature(void *avc, const char *feature, int want_sample); |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3946 |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3947 /** |
9893
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3948 * Logs a generic warning message asking for a sample. This function is |
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3949 * intended to be used internally by FFmpeg (libavcodec, libavformat, etc.) |
1d10ec092b64
Add doxy to av_log_missing_feature() etc. stating that the function is
rbultje
parents:
9892
diff
changeset
|
3950 * only, and would normally not be used by applications. |
9892
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3951 * @param[in] avc a pointer to an arbitrary struct of which the first field is |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3952 * a pointer to an AVClass struct |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3953 * @param[in] msg string containing an optional message, or NULL if no message |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3954 */ |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3955 void av_log_ask_for_sample(void *avc, const char *msg); |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3956 |
b5ca6219e173
Move av_log_missing_feature() from the internal.h to the public avcodec.h
rbultje
parents:
9882
diff
changeset
|
3957 /** |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3958 * Registers the hardware accelerator hwaccel. |
9012
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3959 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3960 void av_register_hwaccel(AVHWAccel *hwaccel); |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3961 |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3962 /** |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3963 * If hwaccel is NULL, returns the first registered hardware accelerator, |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3964 * if hwaccel is non-NULL, returns the next registered hardware accelerator |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3965 * after hwaccel, or NULL if hwaccel is the last one. |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3966 */ |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3967 AVHWAccel *av_hwaccel_next(AVHWAccel *hwaccel); |
15a3df8c01fd
More approved hunks for VAAPI & our new and cleaner hwaccel API.
michael
parents:
9000
diff
changeset
|
3968 |
9742 | 3969 |
3970 /** | |
3971 * Lock operation used by lockmgr | |
3972 */ | |
3973 enum AVLockOp { | |
3974 AV_LOCK_CREATE, ///< Create a mutex | |
3975 AV_LOCK_OBTAIN, ///< Lock the mutex | |
3976 AV_LOCK_RELEASE, ///< Unlock the mutex | |
3977 AV_LOCK_DESTROY, ///< Free mutex resources | |
3978 }; | |
3979 | |
3980 /** | |
3981 * Register a user provided lock manager supporting the operations | |
9822
2887f410011f
Remove '\p', '\c' and '\e' doxygen markup from doxy, as it should
stefano
parents:
9786
diff
changeset
|
3982 * specified by AVLockOp. mutex points to a (void *) where the |
9742 | 3983 * lockmgr should store/get a pointer to a user allocated mutex. It's |
3984 * NULL upon AV_LOCK_CREATE and != NULL for all other ops. | |
3985 * | |
3986 * @param cb User defined callback. Note: FFmpeg may invoke calls to this | |
3987 * callback during the call to av_lockmgr_register(). | |
3988 * Thus, the application must be prepared to handle that. | |
3989 * If cb is set to NULL the lockmgr will be unregistered. | |
3990 * Also note that during unregistration the previously registered | |
3991 * lockmgr callback may also be invoked. | |
3992 */ | |
3993 int av_lockmgr_register(int (*cb)(void **mutex, enum AVLockOp op)); | |
3994 | |
7760 | 3995 #endif /* AVCODEC_AVCODEC_H */ |