blob: 25987a28a0680b0b6ea6e87d82e7514535d2b839 [file] [log] [blame]
/*
* Copyright (C) 2014 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
* This file defines an NDK API.
* Do not remove methods.
* Do not change method signatures.
* Do not change the value of constants.
* Do not change the size of any of the classes defined in here.
* Do not reference types that are not part of the NDK.
* Do not #include files that aren't part of the NDK.
*/
#ifndef _NDK_MEDIA_MUXER_H
#define _NDK_MEDIA_MUXER_H
#include <sys/cdefs.h>
#include <sys/types.h>
#include "NdkMediaCodec.h"
#include "NdkMediaError.h"
#include "NdkMediaFormat.h"
#ifdef __cplusplus
extern "C" {
#endif
#if __ANDROID_API__ >= 21
struct AMediaMuxer;
typedef struct AMediaMuxer AMediaMuxer;
typedef enum {
AMEDIAMUXER_OUTPUT_FORMAT_MPEG_4 = 0,
AMEDIAMUXER_OUTPUT_FORMAT_WEBM = 1,
} OutputFormat;
/**
* Create new media muxer
*/
AMediaMuxer* AMediaMuxer_new(int fd, OutputFormat format);
/**
* Delete a previously created media muxer
*/
media_status_t AMediaMuxer_delete(AMediaMuxer*);
/**
* Set and store the geodata (latitude and longitude) in the output file.
* This method should be called before AMediaMuxer_start. The geodata is stored
* in udta box if the output format is AMEDIAMUXER_OUTPUT_FORMAT_MPEG_4, and is
* ignored for other output formats.
* The geodata is stored according to ISO-6709 standard.
*
* Both values are specified in degrees.
* Latitude must be in the range [-90, 90].
* Longitude must be in the range [-180, 180].
*/
media_status_t AMediaMuxer_setLocation(AMediaMuxer*, float latitude, float longitude);
/**
* Sets the orientation hint for output video playback.
* This method should be called before AMediaMuxer_start. Calling this
* method will not rotate the video frame when muxer is generating the file,
* but add a composition matrix containing the rotation angle in the output
* video if the output format is AMEDIAMUXER_OUTPUT_FORMAT_MPEG_4, so that a
* video player can choose the proper orientation for playback.
* Note that some video players may choose to ignore the composition matrix
* during playback.
* The angle is specified in degrees, clockwise.
* The supported angles are 0, 90, 180, and 270 degrees.
*/
media_status_t AMediaMuxer_setOrientationHint(AMediaMuxer*, int degrees);
/**
* Adds a track with the specified format.
* Returns the index of the new track or a negative value in case of failure,
* which can be interpreted as a media_status_t.
*/
ssize_t AMediaMuxer_addTrack(AMediaMuxer*, const AMediaFormat* format);
/**
* Start the muxer. Should be called after AMediaMuxer_addTrack and
* before AMediaMuxer_writeSampleData.
*/
media_status_t AMediaMuxer_start(AMediaMuxer*);
/**
* Stops the muxer.
* Once the muxer stops, it can not be restarted.
*/
media_status_t AMediaMuxer_stop(AMediaMuxer*);
/**
* Writes an encoded sample into the muxer.
* The application needs to make sure that the samples are written into
* the right tracks. Also, it needs to make sure the samples for each track
* are written in chronological order (e.g. in the order they are provided
* by the encoder.)
*/
media_status_t AMediaMuxer_writeSampleData(AMediaMuxer *muxer,
size_t trackIdx, const uint8_t *data, const AMediaCodecBufferInfo *info);
#endif /* __ANDROID_API__ >= 21 */
#ifdef __cplusplus
} // extern "C"
#endif
#endif // _NDK_MEDIA_MUXER_H