1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
|
page.title=Supported Media Formats
page.tags="video","audio","mpeg","mp4","m4a","mp3","3gp","3gpp","flac","wave","wav"
@jd:body
<div id="qv-wrapper">
<div id="qv">
<h2>In this document</h2>
<ol>
<li><a href="#network">Network Protocols</a></li>
<li><a href="#core">Core Media Formats</a></li>
<li><a href="#recommendations">Video Encoding Recommendations</a></li>
</ol>
<h2>See also</h2>
<ol>
<li><a href="{@docRoot}guide/topics/media/index.html">Multimedia and Camera</a></li>
</ol>
<h2>Key classes</h2>
<ol>
<li>{@link android.media.MediaPlayer MediaPlayer}</li>
<li>{@link android.media.MediaRecorder MediaRecorder}</li>
</ol>
</div>
</div>
<p>This document describes the media codec, container, and network protocol support provided by the Android platform.</p>
<p>As an application developer, you are free to make use of any media codec that is available on any Android-powered device, including those provided by the Android platform and those that are device-specific. <strong>However, it is a best practice to use media encoding profiles that are device-agnostic</strong>.</p>
<h2 id="network">Network Protocols</h2>
<p>The following network protocols are supported for audio and video playback:</p>
<ul>
<li>RTSP (RTP, SDP)</li>
<li>HTTP/HTTPS progressive streaming</li>
<li>HTTP/HTTPS live streaming <a href="http://tools.ietf.org/html/draft-pantos-http-live-streaming">draft protocol</a>: <ul>
<li>MPEG-2 TS media files only</li>
<li>Protocol version 3 (Android 4.0 and above)</li>
<li>Protocol version 2 (Android 3.x)</li>
<li>Not supported before Android 3.0</li>
</ul></li>
</ul>
<p class="note"><strong>Note:</strong> HTTPS is not supported before Android 3.1.</p>
<h2 id="core">Core Media Formats</h2>
<p>The table below describes the media format support built into the Android platform. Note that any given mobile device may provide support for additional formats or file types not listed in the table.</p>
<p class="note"><strong>Note:</strong> Media codecs that are not guaranteed to be available on all Android platform versions are accordingly noted in parentheses—for example "(Android 3.0+)".</p>
<p class="table-caption" id="formats-table"><strong>Table 1.</strong> Core media format and codec support.</p>
<table style="font-size:12px">
<tbody>
<tr>
<th>Type</th>
<th>Format / Codec</th>
<th>Encoder</th>
<th>Decoder</th>
<th>Details</th>
<th>Supported File Type(s) / Container Formats</th>
</tr>
<tr>
<td rowspan="11">Audio</td>
<td>AAC LC</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td rowspan="2">Support for mono/stereo/5.0/5.1
content with standard sampling rates from 8 to 48 kHz.</td>
<td rowspan="4">
• 3GPP (.3gp)<br>
<nobr>• MPEG-4 (.mp4, .m4a)</nobr><br>
• ADTS raw AAC (.aac, decode in Android 3.1+, encode in Android 4.0+, ADIF not supported)<br>
• MPEG-TS (.ts, not seekable, Android 3.0+)</td>
</tr>
<tr>
<td>HE-AACv1 (AAC+)</td>
<td style="text-align: center;"><big>•</big><br><small>(Android 4.1+)</small></td>
<td style="text-align: center;"><big>•</big></td>
</tr>
<tr>
<td>HE-AACv2 (enhanced AAC+)</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td>Support for stereo/5.0/5.1
content with standard sampling rates from 8 to 48 kHz.</td>
</tr>
<tr>
<td>AAC ELD (enhanced low delay AAC)</td>
<td style="text-align: center;"><big>•</big><br><small>(Android 4.1+)</small></td>
<td style="text-align: center;"><big>•</big><br><small>(Android 4.1+)</small></td>
<td>Support for mono/stereo content
with standard sampling rates from 16 to 48 kHz</td>
</tr>
<tr>
<td>AMR-NB</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td>4.75 to 12.2 kbps sampled @ 8kHz</td>
<td>
3GPP (.3gp)</td>
</tr>
<tr>
<td>AMR-WB</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td>9 rates from 6.60 kbit/s to 23.85 kbit/s sampled @ 16kHz</td>
<td>
3GPP (.3gp)</td>
</tr>
<tr>
<td>FLAC</td>
<td> </td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 3.1+)</small></td>
<td>Mono/Stereo (no multichannel). Sample rates up to 48 kHz (but up to 44.1
kHz is recommended on devices with 44.1 kHz output, as the 48 to 44.1 kHz
downsampler does not include a low-pass filter). 16-bit recommended;
no dither applied for 24-bit.
</td>
<td>
FLAC (.flac) only</td>
</tr>
<tr>
<td>MP3</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td>Mono/Stereo 8-320Kbps constant (CBR) or variable bit-rate (VBR)
</td>
<td>
MP3 (.mp3)</td>
</tr>
<tr>
<td>MIDI</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td>MIDI Type 0 and 1. DLS Version 1 and 2. XMF and Mobile XMF. Support for ringtone formats RTTTL/RTX, OTA, and iMelody </td>
<td>
• Type 0 and 1 (.mid, .xmf, .mxmf)<br>
• RTTTL/RTX (.rtttl, .rtx)<br>
• OTA (.ota)<br>
• iMelody (.imy)</td>
</tr>
<tr>
<td>Vorbis</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
• Ogg (.ogg)<br>
• Matroska (.mkv, Android 4.0+)</td>
</tr>
<tr>
<td>PCM/WAVE</td>
<td style="text-align: center;"><big>•</big><br><small>(Android 4.1+)</small></td>
<td style="text-align: center;"><big>•</big></td>
<td>8- and 16-bit linear PCM (rates up to limit of hardware). Sampling
rates for raw PCM recordings at 8000, 16000 and 44100 Hz.</td>
<td>
WAVE (.wav)</td>
</tr>
<tr>
<td rowspan="5">Image</td>
<td>JPEG</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td>Base+progressive</td>
<td>
JPEG (.jpg)</td>
</tr>
<tr>
<td>GIF</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
GIF (.gif)</td>
</tr>
<tr>
<td>PNG</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
PNG (.png)</td>
</tr>
<tr>
<td>BMP</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
BMP (.bmp)</td>
</tr>
<tr>
<td>WEBP</td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 4.0+)</small></td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 4.0+)</small></td>
<td> </td>
<td>
WebP (.webp)</td>
</tr>
<tr>
<td rowspan="4">Video</td>
<td>H.263</td>
<td style="text-align: center;"><big>•</big></td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
• 3GPP (.3gp)<br>
• MPEG-4 (.mp4)</td>
</tr>
<tr>
<td>H.264 AVC</td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 3.0+)</small></td>
<td style="text-align: center;" nowrap><big>•</big></td>
<td>Baseline Profile (BP)</td>
<td>
• 3GPP (.3gp)<br>
• MPEG-4 (.mp4)<br>
• MPEG-TS (.ts, AAC audio only, not seekable, Android 3.0+)</td>
</tr>
<tr>
<td>MPEG-4 SP</td>
<td> </td>
<td style="text-align: center;"><big>•</big></td>
<td> </td>
<td>
3GPP (.3gp)</td>
</tr>
<tr>
<td>VP8</td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 4.3+)</small></td>
<td style="text-align: center;" nowrap><big>•</big><br><small>(Android 2.3.3+)</small></td>
<td>Streamable only in Android 4.0 and above</td>
<td>
• <a href="http://www.webmproject.org/">WebM</a> (.webm)<br>
• Matroska (.mkv, Android 4.0+)</td>
</tr>
</tbody></table>
<h2 id="recommendations">Video Encoding Recommendations</h2>
<p>Table 2, below, lists examples of video encoding profiles and parameters that the Android
media framework supports for playback in the H.264 Baseline Profile codec. While
table 3 lists examples that the framework supports for playback in the VP8 media codec.</p>
<p>In addition to these encoding parameter recommendations,
a device's available <em>video recording</em> profiles can be used as a proxy for media playback
capabilities. These profiles can be inspected using the {@link android.media.CamcorderProfile
CamcorderProfile} class, which is available since API level 8.</p>
<p class="table-caption" id="encoding-recommendations-table"><strong>Table 2.</strong>
Examples of supported video encoding parameters for the H.264 Baseline Profile codec.</p>
<table>
<thead>
<tr>
<th> </th>
<th><acronym title="Standard definition">SD</a> (Low quality)</th>
<th><acronym title="Standard definition">SD</a> (High quality)</th>
<th><acronym title="High definition">HD 720p</a> (N/A on all devices)</th>
</tr>
</thead>
<tbody>
<tr>
<th>Video resolution</th>
<td>176 x 144 px</td>
<td>480 x 360 px</td>
<td>1280 x 720 px</td>
</tr>
<tr>
<th>Video frame rate</th>
<td>12 fps</td>
<td>30 fps</td>
<td>30 fps</td>
</tr>
<tr>
<th>Video bitrate</th>
<td>56 Kbps</td>
<td>500 Kbps</td>
<td>2 Mbps</td>
</tr>
<tr>
<th>Audio codec</th>
<td>AAC-LC</td>
<td>AAC-LC</td>
<td>AAC-LC</td>
</tr>
<tr>
<th>Audio channels</th>
<td>1 (mono)</td>
<td>2 (stereo)</td>
<td>2 (stereo)</td>
</tr>
<tr>
<th>Audio bitrate</th>
<td>24 Kbps</td>
<td>128 Kbps</td>
<td>192 Kbps</td>
</tr>
</tbody>
</table>
<p class="table-caption" id="encoding-recommendations-table-vp8"><strong>Table 3.</strong>
Examples of supported video encoding parameters for the VP8 codec.</p>
<table>
<thead>
<tr>
<th> </th>
<th><acronym title="Standard definition">SD</a> (Low quality)</th>
<th><acronym title="Standard definition">SD</a> (High quality)</th>
<th><acronym title="High definition">HD 720p</a> (N/A on all devices)</th>
<th><acronym title="High definition">HD 1080p</a> (N/A on all devices)</th>
</tr>
</thead>
<tbody>
<tr>
<th>Video resolution</th>
<td>320 x 180 px</td>
<td>640 x 360 px</td>
<td>1280 x 720 px</td>
<td>1920 x 1080 px</td>
</tr>
<tr>
<th>Video frame rate</th>
<td>30 fps</td>
<td>30 fps</td>
<td>30 fps</td>
<td>30 fps</td>
</tr>
<tr>
<th>Video bitrate</th>
<td>800 Kbps</td>
<td>2 Mbps</td>
<td>4 Mbps</td>
<td>10 Mbps</td>
</tr>
</tbody>
</table>
<p style="margin-top: 2em">For video content that is streamed over HTTP or RTSP, there are additional requirements:</p>
<ul>
<li>For 3GPP and MPEG-4 containers, the <code>moov</code> atom must precede any <code>mdat</code> atoms, but must succeed the
<code>ftyp</code> atom.</li>
<li>For 3GPP, MPEG-4, and WebM containers, audio and video samples corresponding to the same time offset may be no more than 500 KB apart.
To minimize this audio/video drift, consider interleaving audio and video in smaller chunk sizes.</li>
</ul>
|