diff options
author | Marco Nelissen <marcone@google.com> | 2014-05-06 16:08:19 -0700 |
---|---|---|
committer | Marco Nelissen <marcone@google.com> | 2014-05-07 09:57:08 -0700 |
commit | 08aaabe87960c04ecac180db1fe88b5a7bc2ed3b (patch) | |
tree | 740a80ccc357b0a138445b2728c32ee9762db745 /include | |
parent | 8e085cbeccb1138d52a0a423af02e6ab41b4fee4 (diff) | |
download | frameworks_av-08aaabe87960c04ecac180db1fe88b5a7bc2ed3b.zip frameworks_av-08aaabe87960c04ecac180db1fe88b5a7bc2ed3b.tar.gz frameworks_av-08aaabe87960c04ecac180db1fe88b5a7bc2ed3b.tar.bz2 |
Add NDK version of MediaMuxer
and add some constness here and there.
Change-Id: Ib3caa8310691e8f27aaa1afcfaec0b384513d4f1
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 |