diff options
author | Marco Nelissen <marcone@google.com> | 2014-05-07 19:55:09 +0000 |
---|---|---|
committer | Android (Google) Code Review <android-gerrit@google.com> | 2014-05-07 19:55:10 +0000 |
commit | 0dd3c9cb0ed66888c224a97d817701df6c3b2655 (patch) | |
tree | 488257fb4ade824040ed884bdb7949402ff9af2e /include | |
parent | a079461668e881718fa6c0de967e557f59da1cab (diff) | |
parent | 08aaabe87960c04ecac180db1fe88b5a7bc2ed3b (diff) | |
download | frameworks_av-0dd3c9cb0ed66888c224a97d817701df6c3b2655.zip frameworks_av-0dd3c9cb0ed66888c224a97d817701df6c3b2655.tar.gz frameworks_av-0dd3c9cb0ed66888c224a97d817701df6c3b2655.tar.bz2 |
Merge "Add NDK version of MediaMuxer"
Diffstat (limited to 'include')
-rw-r--r-- | include/ndk/NdkMediaCodec.h | 2 | ||||
-rw-r--r-- | include/ndk/NdkMediaMuxer.h | 75 |
2 files changed, 76 insertions, 1 deletions
diff --git a/include/ndk/NdkMediaCodec.h b/include/ndk/NdkMediaCodec.h index 5067073..73ece1b 100644 --- a/include/ndk/NdkMediaCodec.h +++ b/include/ndk/NdkMediaCodec.h @@ -79,7 +79,7 @@ int AMediaCodec_delete(AMediaCodec*); /** * Configure the codec. For decoding you would typically get the format from an extractor. */ -int AMediaCodec_configure(AMediaCodec*, AMediaFormat *format, ANativeWindow* surface); // TODO: other args +int AMediaCodec_configure(AMediaCodec*, const AMediaFormat* format, ANativeWindow* surface); // TODO: other args /** * Start the codec. A codec must be configured before it can be started, and must be started diff --git a/include/ndk/NdkMediaMuxer.h b/include/ndk/NdkMediaMuxer.h new file mode 100644 index 0000000..deb150d --- /dev/null +++ b/include/ndk/NdkMediaMuxer.h @@ -0,0 +1,75 @@ +/* + * 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/types.h> + +#include "NdkMediaFormat.h" +#include "NdkMediaCodec.h" + +#ifdef __cplusplus +extern "C" { +#endif + +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 + */ +int AMediaMuxer_delete(AMediaMuxer*); + +int AMediaMuxer_setLocation(AMediaMuxer*, float latitude, float longtitude); + +int AMediaMuxer_setOrientationHint(AMediaMuxer*, int degrees); + +ssize_t AMediaMuxer_addTrack(AMediaMuxer*, const AMediaFormat* format); + +int AMediaMuxer_start(AMediaMuxer*); + +int AMediaMuxer_stop(AMediaMuxer*); + +int AMediaMuxer_writeSampleData(AMediaMuxer *muxer, + size_t trackIdx, const uint8_t *data, const AMediaCodecBufferInfo &info); + +#ifdef __cplusplus +} // extern "C" +#endif + +#endif // _NDK_MEDIA_MUXER_H |