diff options
author | ztenghui <ztenghui@google.com> | 2013-05-31 11:07:35 -0700 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2013-05-31 11:07:35 -0700 |
commit | 43590eb76cac78f780dd318492c5fe6093e2fa88 (patch) | |
tree | 4125824fcb73b996a88f662ffa1f7a5ea17b182d /media/java | |
parent | 6caecdebbf568782cab5c8ad4536683e5c25e7ff (diff) | |
parent | 4f0002e6de601f6727475a3296618120b62d7f12 (diff) | |
download | frameworks_base-43590eb76cac78f780dd318492c5fe6093e2fa88.zip frameworks_base-43590eb76cac78f780dd318492c5fe6093e2fa88.tar.gz frameworks_base-43590eb76cac78f780dd318492c5fe6093e2fa88.tar.bz2 |
am 4f0002e6: Merge "MediaMuxer sample code update, no functional change" into jb-mr2-dev
* commit '4f0002e6de601f6727475a3296618120b62d7f12':
MediaMuxer sample code update, no functional change
Diffstat (limited to 'media/java')
-rw-r--r-- | media/java/android/media/MediaMuxer.java | 25 |
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> |