blob: e0caeabba1c2f5ef8eb22a38d98dc4456ef4184f [file] [log] [blame]
Marco Nelissen0c3be872014-05-01 10:14:44 -07001/*
2 * Copyright (C) 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17/*
18 * This file defines an NDK API.
19 * Do not remove methods.
20 * Do not change method signatures.
21 * Do not change the value of constants.
22 * Do not change the size of any of the classes defined in here.
23 * Do not reference types that are not part of the NDK.
24 * Do not #include files that aren't part of the NDK.
25 */
26
27#ifndef _NDK_MEDIA_FORMAT_H
28#define _NDK_MEDIA_FORMAT_H
29
30#include <sys/types.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
36struct AMediaFormat;
37typedef struct AMediaFormat AMediaFormat;
38
39AMediaFormat *AMediaFormat_new();
40int AMediaFormat_delete(AMediaFormat*);
41
42/**
Marco Nelissen7c9b1412014-05-06 10:33:07 -070043 * Human readable representation of the format. The returned string is owned by the format,
44 * and remains valid until the next call to toString, or until the format is deleted.
Marco Nelissen0c3be872014-05-01 10:14:44 -070045 */
46const char* AMediaFormat_toString(AMediaFormat*);
47
48bool AMediaFormat_getInt32(AMediaFormat*, const char *name, int32_t *out);
49bool AMediaFormat_getInt64(AMediaFormat*, const char *name, int64_t *out);
50bool AMediaFormat_getFloat(AMediaFormat*, const char *name, float *out);
Marco Nelissen34d49722014-05-07 12:55:18 -070051/**
52 * The returned data is owned by the format and remains valid as long as the named entry
53 * is part of the format.
54 */
55bool AMediaFormat_getBuffer(AMediaFormat*, const char *name, void** data, size_t *size);
Marco Nelissen0c3be872014-05-01 10:14:44 -070056/**
Marco Nelissen7c9b1412014-05-06 10:33:07 -070057 * The returned string is owned by the format, and remains valid until the next call to getString,
58 * or until the format is deleted.
Marco Nelissen0c3be872014-05-01 10:14:44 -070059 */
60bool AMediaFormat_getString(AMediaFormat*, const char *name, const char **out);
61
Marco Nelissen34d49722014-05-07 12:55:18 -070062
63void AMediaFormat_setInt32(AMediaFormat*, const char* name, int32_t value);
64void AMediaFormat_setInt64(AMediaFormat*, const char* name, int64_t value);
65void AMediaFormat_setFloat(AMediaFormat*, const char* name, float value);
66/**
67 * The provided string is copied into the format.
68 */
69void AMediaFormat_setString(AMediaFormat*, const char* name, const char* value);
70/**
71 * The provided data is copied into the format.
72 */
73void AMediaFormat_setBuffer(AMediaFormat*, const char* name, void* data, size_t size);
74
75
76
Marco Nelissen0c3be872014-05-01 10:14:44 -070077/**
78 * XXX should these be ints/enums that we look up in a table as needed?
79 */
80extern const char* AMEDIAFORMAT_KEY_AAC_PROFILE;
81extern const char* AMEDIAFORMAT_KEY_BIT_RATE;
82extern const char* AMEDIAFORMAT_KEY_CHANNEL_COUNT;
83extern const char* AMEDIAFORMAT_KEY_CHANNEL_MASK;
84extern const char* AMEDIAFORMAT_KEY_COLOR_FORMAT;
85extern const char* AMEDIAFORMAT_KEY_DURATION;
86extern const char* AMEDIAFORMAT_KEY_FLAC_COMPRESSION_LEVEL;
87extern const char* AMEDIAFORMAT_KEY_FRAME_RATE;
88extern const char* AMEDIAFORMAT_KEY_HEIGHT;
89extern const char* AMEDIAFORMAT_KEY_IS_ADTS;
90extern const char* AMEDIAFORMAT_KEY_IS_AUTOSELECT;
91extern const char* AMEDIAFORMAT_KEY_IS_DEFAULT;
92extern const char* AMEDIAFORMAT_KEY_IS_FORCED_SUBTITLE;
93extern const char* AMEDIAFORMAT_KEY_I_FRAME_INTERVAL;
94extern const char* AMEDIAFORMAT_KEY_LANGUAGE;
95extern const char* AMEDIAFORMAT_KEY_MAX_HEIGHT;
96extern const char* AMEDIAFORMAT_KEY_MAX_INPUT_SIZE;
97extern const char* AMEDIAFORMAT_KEY_MAX_WIDTH;
98extern const char* AMEDIAFORMAT_KEY_MIME;
99extern const char* AMEDIAFORMAT_KEY_PUSH_BLANK_BUFFERS_ON_STOP;
100extern const char* AMEDIAFORMAT_KEY_REPEAT_PREVIOUS_FRAME_AFTER;
101extern const char* AMEDIAFORMAT_KEY_SAMPLE_RATE;
102extern const char* AMEDIAFORMAT_KEY_WIDTH;
103extern const char* AMEDIAFORMAT_KEY_STRIDE;
104
105#ifdef __cplusplus
106} // extern "C"
107#endif
108
109#endif // _NDK_MEDIA_FORMAT_H