16269d53cce5c1c9350565d3d72d92116594260cbztenghui/*
26269d53cce5c1c9350565d3d72d92116594260cbztenghui * Copyright 2013, The Android Open Source Project
36269d53cce5c1c9350565d3d72d92116594260cbztenghui *
46269d53cce5c1c9350565d3d72d92116594260cbztenghui * Licensed under the Apache License, Version 2.0 (the "License");
56269d53cce5c1c9350565d3d72d92116594260cbztenghui * you may not use this file except in compliance with the License.
66269d53cce5c1c9350565d3d72d92116594260cbztenghui * You may obtain a copy of the License at
76269d53cce5c1c9350565d3d72d92116594260cbztenghui *
86269d53cce5c1c9350565d3d72d92116594260cbztenghui *     http://www.apache.org/licenses/LICENSE-2.0
96269d53cce5c1c9350565d3d72d92116594260cbztenghui *
106269d53cce5c1c9350565d3d72d92116594260cbztenghui * Unless required by applicable law or agreed to in writing, software
116269d53cce5c1c9350565d3d72d92116594260cbztenghui * distributed under the License is distributed on an "AS IS" BASIS,
126269d53cce5c1c9350565d3d72d92116594260cbztenghui * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
136269d53cce5c1c9350565d3d72d92116594260cbztenghui * See the License for the specific language governing permissions and
146269d53cce5c1c9350565d3d72d92116594260cbztenghui * limitations under the License.
156269d53cce5c1c9350565d3d72d92116594260cbztenghui */
166269d53cce5c1c9350565d3d72d92116594260cbztenghui
176269d53cce5c1c9350565d3d72d92116594260cbztenghui#ifndef MEDIA_MUXER_H_
186269d53cce5c1c9350565d3d72d92116594260cbztenghui#define MEDIA_MUXER_H_
196269d53cce5c1c9350565d3d72d92116594260cbztenghui
206269d53cce5c1c9350565d3d72d92116594260cbztenghui#include <utils/Errors.h>
216269d53cce5c1c9350565d3d72d92116594260cbztenghui#include <utils/RefBase.h>
226269d53cce5c1c9350565d3d72d92116594260cbztenghui#include <utils/Vector.h>
236269d53cce5c1c9350565d3d72d92116594260cbztenghui#include <utils/threads.h>
246269d53cce5c1c9350565d3d72d92116594260cbztenghui
25dff843f2fae88c10fe18d2925a4e802a35d74433Bernhard Rosenkraenzer#include "foundation/ABase.h"
26dff843f2fae88c10fe18d2925a4e802a35d74433Bernhard Rosenkraenzer
276269d53cce5c1c9350565d3d72d92116594260cbztenghuinamespace android {
286269d53cce5c1c9350565d3d72d92116594260cbztenghui
296269d53cce5c1c9350565d3d72d92116594260cbztenghuistruct ABuffer;
306269d53cce5c1c9350565d3d72d92116594260cbztenghuistruct AMessage;
316269d53cce5c1c9350565d3d72d92116594260cbztenghuistruct MediaAdapter;
32ee4e1b1a63758941460ae79a064249d3a5189443Lajos Molnarclass MediaBuffer;
336269d53cce5c1c9350565d3d72d92116594260cbztenghuistruct MediaSource;
34ee4e1b1a63758941460ae79a064249d3a5189443Lajos Molnarclass MetaData;
35343947abc8b7c126f966fd32a0b18bff6c2cecd1Robert Shihstruct MediaWriter;
366269d53cce5c1c9350565d3d72d92116594260cbztenghui
376269d53cce5c1c9350565d3d72d92116594260cbztenghui// MediaMuxer is used to mux multiple tracks into a video. Currently, we only
386269d53cce5c1c9350565d3d72d92116594260cbztenghui// support a mp4 file as the output.
396269d53cce5c1c9350565d3d72d92116594260cbztenghui// The expected calling order of the functions is:
406269d53cce5c1c9350565d3d72d92116594260cbztenghui// Constructor -> addTrack+ -> start -> writeSampleData+ -> stop
416269d53cce5c1c9350565d3d72d92116594260cbztenghui// If muxing operation need to be cancelled, the app is responsible for
426269d53cce5c1c9350565d3d72d92116594260cbztenghui// deleting the output file after stop.
436269d53cce5c1c9350565d3d72d92116594260cbztenghuistruct MediaMuxer : public RefBase {
446269d53cce5c1c9350565d3d72d92116594260cbztenghuipublic:
45afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui    // Please update media/java/android/media/MediaMuxer.java if the
46afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui    // OutputFormat is updated.
47afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui    enum OutputFormat {
48afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui        OUTPUT_FORMAT_MPEG_4 = 0,
49343947abc8b7c126f966fd32a0b18bff6c2cecd1Robert Shih        OUTPUT_FORMAT_WEBM   = 1,
50afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui        OUTPUT_FORMAT_LIST_END // must be last - used to validate format type
51afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui    };
52afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui
536269d53cce5c1c9350565d3d72d92116594260cbztenghui    // Construct the muxer with the file descriptor. Note that the MediaMuxer
546269d53cce5c1c9350565d3d72d92116594260cbztenghui    // will close this file at stop().
55afde4e56566af19b36f1fe5e7aa7f226bf1703ddztenghui    MediaMuxer(int fd, OutputFormat format);
566269d53cce5c1c9350565d3d72d92116594260cbztenghui
576269d53cce5c1c9350565d3d72d92116594260cbztenghui    virtual ~MediaMuxer();
586269d53cce5c1c9350565d3d72d92116594260cbztenghui
596269d53cce5c1c9350565d3d72d92116594260cbztenghui    /**
606269d53cce5c1c9350565d3d72d92116594260cbztenghui     * Add a track with its format information. This should be
616269d53cce5c1c9350565d3d72d92116594260cbztenghui     * called before start().
626269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @param format the track's format.
636269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @return the track's index or negative number if error.
646269d53cce5c1c9350565d3d72d92116594260cbztenghui     */
656269d53cce5c1c9350565d3d72d92116594260cbztenghui    ssize_t addTrack(const sp<AMessage> &format);
666269d53cce5c1c9350565d3d72d92116594260cbztenghui
676269d53cce5c1c9350565d3d72d92116594260cbztenghui    /**
686269d53cce5c1c9350565d3d72d92116594260cbztenghui     * Start muxing. Make sure all the tracks have been added before
696269d53cce5c1c9350565d3d72d92116594260cbztenghui     * calling this.
706269d53cce5c1c9350565d3d72d92116594260cbztenghui     */
716269d53cce5c1c9350565d3d72d92116594260cbztenghui    status_t start();
726269d53cce5c1c9350565d3d72d92116594260cbztenghui
736269d53cce5c1c9350565d3d72d92116594260cbztenghui    /**
7411287471298193ff51ffb429686f5d63a84a621bztenghui     * Set the orientation hint.
7511287471298193ff51ffb429686f5d63a84a621bztenghui     * @param degrees The rotation degrees. It has to be either 0,
7611287471298193ff51ffb429686f5d63a84a621bztenghui     *                90, 180 or 270.
7711287471298193ff51ffb429686f5d63a84a621bztenghui     * @return OK if no error.
7811287471298193ff51ffb429686f5d63a84a621bztenghui     */
7911287471298193ff51ffb429686f5d63a84a621bztenghui    status_t setOrientationHint(int degrees);
8011287471298193ff51ffb429686f5d63a84a621bztenghui
8111287471298193ff51ffb429686f5d63a84a621bztenghui    /**
827f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * Set the location.
837f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * @param latitude The latitude in degree x 1000. Its value must be in the range
847f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * [-900000, 900000].
857f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * @param longitude The longitude in degree x 1000. Its value must be in the range
867f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * [-1800000, 1800000].
877f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     * @return OK if no error.
887f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He     */
897f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He    status_t setLocation(int latitude, int longitude);
907f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He
917f9551f75eedb3e4e1fe8feaaba48d8080635fc4Zhijun He    /**
926269d53cce5c1c9350565d3d72d92116594260cbztenghui     * Stop muxing.
936269d53cce5c1c9350565d3d72d92116594260cbztenghui     * This method is a blocking call. Depending on how
946269d53cce5c1c9350565d3d72d92116594260cbztenghui     * much data is bufferred internally, the time needed for stopping
956269d53cce5c1c9350565d3d72d92116594260cbztenghui     * the muxer may be time consuming. UI thread is
966269d53cce5c1c9350565d3d72d92116594260cbztenghui     * not recommended for launching this call.
9711287471298193ff51ffb429686f5d63a84a621bztenghui     * @return OK if no error.
986269d53cce5c1c9350565d3d72d92116594260cbztenghui     */
996269d53cce5c1c9350565d3d72d92116594260cbztenghui    status_t stop();
1006269d53cce5c1c9350565d3d72d92116594260cbztenghui
1016269d53cce5c1c9350565d3d72d92116594260cbztenghui    /**
1026269d53cce5c1c9350565d3d72d92116594260cbztenghui     * Send a sample buffer for muxing.
1036269d53cce5c1c9350565d3d72d92116594260cbztenghui     * The buffer can be reused once this method returns. Typically,
1046269d53cce5c1c9350565d3d72d92116594260cbztenghui     * this function won't be blocked for very long, and thus there
1056269d53cce5c1c9350565d3d72d92116594260cbztenghui     * is no need to use a separate thread calling this method to
1066269d53cce5c1c9350565d3d72d92116594260cbztenghui     * push a buffer.
1076269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @param buffer the incoming sample buffer.
1086269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @param trackIndex the buffer's track index number.
1096269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @param timeUs the buffer's time stamp.
1106269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @param flags the only supported flag for now is
1116269d53cce5c1c9350565d3d72d92116594260cbztenghui     *              MediaCodec::BUFFER_FLAG_SYNCFRAME.
1126269d53cce5c1c9350565d3d72d92116594260cbztenghui     * @return OK if no error.
1136269d53cce5c1c9350565d3d72d92116594260cbztenghui     */
1146269d53cce5c1c9350565d3d72d92116594260cbztenghui    status_t writeSampleData(const sp<ABuffer> &buffer, size_t trackIndex,
1156269d53cce5c1c9350565d3d72d92116594260cbztenghui                             int64_t timeUs, uint32_t flags) ;
1166269d53cce5c1c9350565d3d72d92116594260cbztenghui
1176269d53cce5c1c9350565d3d72d92116594260cbztenghuiprivate:
118343947abc8b7c126f966fd32a0b18bff6c2cecd1Robert Shih    const OutputFormat mFormat;
119343947abc8b7c126f966fd32a0b18bff6c2cecd1Robert Shih    sp<MediaWriter> mWriter;
1206269d53cce5c1c9350565d3d72d92116594260cbztenghui    Vector< sp<MediaAdapter> > mTrackList;  // Each track has its MediaAdapter.
12111287471298193ff51ffb429686f5d63a84a621bztenghui    sp<MetaData> mFileMeta;  // Metadata for the whole file.
1226269d53cce5c1c9350565d3d72d92116594260cbztenghui
1236269d53cce5c1c9350565d3d72d92116594260cbztenghui    Mutex mMuxerLock;
1246269d53cce5c1c9350565d3d72d92116594260cbztenghui
1256269d53cce5c1c9350565d3d72d92116594260cbztenghui    enum State {
12611287471298193ff51ffb429686f5d63a84a621bztenghui        UNINITIALIZED,
12711287471298193ff51ffb429686f5d63a84a621bztenghui        INITIALIZED,
1286269d53cce5c1c9350565d3d72d92116594260cbztenghui        STARTED,
1296269d53cce5c1c9350565d3d72d92116594260cbztenghui        STOPPED
1306269d53cce5c1c9350565d3d72d92116594260cbztenghui    };
1316269d53cce5c1c9350565d3d72d92116594260cbztenghui    State mState;
1326269d53cce5c1c9350565d3d72d92116594260cbztenghui
1336269d53cce5c1c9350565d3d72d92116594260cbztenghui    DISALLOW_EVIL_CONSTRUCTORS(MediaMuxer);
1346269d53cce5c1c9350565d3d72d92116594260cbztenghui};
1356269d53cce5c1c9350565d3d72d92116594260cbztenghui
1366269d53cce5c1c9350565d3d72d92116594260cbztenghui}  // namespace android
1376269d53cce5c1c9350565d3d72d92116594260cbztenghui
1386269d53cce5c1c9350565d3d72d92116594260cbztenghui#endif  // MEDIA_MUXER_H_
1396269d53cce5c1c9350565d3d72d92116594260cbztenghui
140