summaryrefslogtreecommitdiffstats
path: root/media
diff options
context:
space:
mode:
authorztenghui <ztenghui@google.com>2013-05-31 18:05:43 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2013-05-31 18:05:43 +0000
commit4f0002e6de601f6727475a3296618120b62d7f12 (patch)
tree386e730b2965a6214b8c8417ce620b2c5cc8b275 /media
parentb5a9e73154d62338852303a3a492de59360b2a17 (diff)
parent34a5b011cd3fe3b231770a3bae984175d2c983e2 (diff)
downloadframeworks_base-4f0002e6de601f6727475a3296618120b62d7f12.zip
frameworks_base-4f0002e6de601f6727475a3296618120b62d7f12.tar.gz
frameworks_base-4f0002e6de601f6727475a3296618120b62d7f12.tar.bz2
Merge "MediaMuxer sample code update, no functional change" into jb-mr2-dev
Diffstat (limited to 'media')
-rw-r--r--media/java/android/media/MediaMuxer.java25
1 files changed, 17 insertions, 8 deletions
diff --git a/media/java/android/media/MediaMuxer.java b/media/java/android/media/MediaMuxer.java
index e49a00e..774964e 100644
--- a/media/java/android/media/MediaMuxer.java
+++ b/media/java/android/media/MediaMuxer.java
@@ -35,20 +35,29 @@ import java.util.Map;
* It is generally used like this:
*
* <pre>
- * MediaMuxer muxer = new MediaMuxer(...);
+ * MediaMuxer muxer = new MediaMuxer("temp.mp4", OutputFormat.MUXER_OUTPUT_MPEG_4);
+ * // More often, the MediaFormat will be retrieved from MediaCodec.getOutputFormat()
+ * // or MediaExtractor.getTrackFormat().
* MediaFormat audioFormat = new MediaFormat(...);
* MediaFormat videoFormat = new MediaFormat(...);
* int audioTrackIndex = muxer.addTrack(audioFormat);
* int videoTrackIndex = muxer.addTrack(videoFormat);
- * ByteBuffer inputBuffer = ByteBuffer.allocate(...);
+ * ByteBuffer inputBuffer = ByteBuffer.allocate(bufferSize);
+ * boolean finished = false;
+ * BufferInfo bufferInfo = new BufferInfo();
+ *
* muxer.start();
- * while(inputBuffer has new data) {
- * if (new data is audio sample) {
- * muxer.writeSampleData(audioTrackIndex, inputBuffer, ...);
- * } else if (new data is video sample) {
- * muxer.writeSampleData(videoTrackIndex, inputBuffer, ...);
+ * while(!finished) {
+ * // getInputBuffer() will fill the inputBuffer with one frame of encoded
+ * // sample from either MediaCodec or MediaExtractor, set isAudioSample to
+ * // true when the sample is audio data, set up all the fields of bufferInfo,
+ * // and return true if there are no more samples.
+ * finished = getInputBuffer(inputBuffer, isAudioSample, bufferInfo);
+ * if (!finished) {
+ * int currentTrackIndex = isAudioSample ? audioTrackIndex : videoTrackIndex;
+ * muxer.writeSampleData(currentTrackIndex, inputBuffer, bufferInfo);
* }
- * }
+ * };
* muxer.stop();
* muxer.release();
* </pre>