blob: f2aec9861749ee81c6662694c5a32b7b1dc1bb8b [file] [log] [blame]
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -08001/*
2 * Copyright (C) 2015 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
Yin-Chia Yeh3e49be12016-04-12 16:00:33 -070017/**
18 * @addtogroup Camera
19 * @{
20 */
21
22/**
23 * @file NdkCameraMetadata.h
24 */
25
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080026/*
27 * This file defines an NDK API.
28 * Do not remove methods.
29 * Do not change method signatures.
30 * Do not change the value of constants.
31 * Do not change the size of any of the classes defined in here.
32 * Do not reference types that are not part of the NDK.
33 * Do not #include files that aren't part of the NDK.
34 */
35
36#ifndef _NDK_CAMERA_METADATA_H
37#define _NDK_CAMERA_METADATA_H
38
Dan Albertd7973ba2016-09-14 12:35:50 -070039#include <sys/cdefs.h>
40
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080041#include "NdkCameraError.h"
42#include "NdkCameraMetadataTags.h"
43
Dan Albertd7973ba2016-09-14 12:35:50 -070044__BEGIN_DECLS
45
46#if __ANDROID_API__ >= 24
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080047
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070048/**
49 * ACameraMetadata is opaque type that provides access to read-only camera metadata like camera
50 * characteristics (via {@link ACameraManager_getCameraCharacteristics}) or capture results (via
51 * {@link ACameraCaptureSession_captureCallback_result}).
52 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080053typedef struct ACameraMetadata ACameraMetadata;
54
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070055/**
56 * Possible data types of a metadata entry.
57 *
58 * Keep in sync with system/media/include/system/camera_metadata.h
59 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080060enum {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070061 /// Unsigned 8-bit integer (uint8_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080062 ACAMERA_TYPE_BYTE = 0,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070063 /// Signed 32-bit integer (int32_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080064 ACAMERA_TYPE_INT32 = 1,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070065 /// 32-bit float (float)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080066 ACAMERA_TYPE_FLOAT = 2,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070067 /// Signed 64-bit integer (int64_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080068 ACAMERA_TYPE_INT64 = 3,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070069 /// 64-bit float (double)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080070 ACAMERA_TYPE_DOUBLE = 4,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070071 /// A 64-bit fraction (ACameraMetadata_rational)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080072 ACAMERA_TYPE_RATIONAL = 5,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070073 /// Number of type fields
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080074 ACAMERA_NUM_TYPES
75};
76
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070077/**
78 * Definition of rational data type in {@link ACameraMetadata}.
79 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080080typedef struct ACameraMetadata_rational {
81 int32_t numerator;
82 int32_t denominator;
83} ACameraMetadata_rational;
84
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070085/**
86 * A single camera metadata entry.
87 *
88 * <p>Each entry is an array of values, though many metadata fields may only have 1 entry in the
89 * array.</p>
90 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080091typedef struct ACameraMetadata_entry {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070092 /**
93 * The tag identifying the entry.
94 *
95 * <p> It is one of the values defined in {@link NdkCameraMetadataTags.h}, and defines how the
96 * entry should be interpreted and which parts of the API provide it.
97 * See {@link NdkCameraMetadataTags.h} for more details. </p>
98 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080099 uint32_t tag;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700100
101 /**
102 * The data type of this metadata entry.
103 *
104 * <p>Must be one of ACAMERA_TYPE_* enum values defined above. A particular tag always has the
105 * same type.</p>
106 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800107 uint8_t type;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700108
109 /**
110 * Count of elements (NOT count of bytes) in this metadata entry.
111 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800112 uint32_t count;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700113
114 /**
115 * Pointer to the data held in this metadata entry.
116 *
117 * <p>The type field above defines which union member pointer is valid. The count field above
118 * defines the length of the data in number of elements.</p>
119 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800120 union {
121 uint8_t *u8;
122 int32_t *i32;
123 float *f;
124 int64_t *i64;
125 double *d;
126 ACameraMetadata_rational* r;
127 } data;
128} ACameraMetadata_entry;
129
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700130/**
131 * A single read-only camera metadata entry.
132 *
133 * <p>Each entry is an array of values, though many metadata fields may only have 1 entry in the
134 * array.</p>
135 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800136typedef struct ACameraMetadata_const_entry {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700137 /**
138 * The tag identifying the entry.
139 *
140 * <p> It is one of the values defined in {@link NdkCameraMetadataTags.h}, and defines how the
141 * entry should be interpreted and which parts of the API provide it.
142 * See {@link NdkCameraMetadataTags.h} for more details. </p>
143 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800144 uint32_t tag;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700145
146 /**
147 * The data type of this metadata entry.
148 *
149 * <p>Must be one of ACAMERA_TYPE_* enum values defined above. A particular tag always has the
150 * same type.</p>
151 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800152 uint8_t type;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700153
154 /**
155 * Count of elements (NOT count of bytes) in this metadata entry.
156 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800157 uint32_t count;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700158
159 /**
160 * Pointer to the data held in this metadata entry.
161 *
162 * <p>The type field above defines which union member pointer is valid. The count field above
163 * defines the length of the data in number of elements.</p>
164 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800165 union {
166 const uint8_t *u8;
167 const int32_t *i32;
168 const float *f;
169 const int64_t *i64;
170 const double *d;
171 const ACameraMetadata_rational* r;
172 } data;
173} ACameraMetadata_const_entry;
174
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700175/**
176 * Get a metadata entry from an input {@link ACameraMetadata}.
177 *
178 * <p>The memory of the data field in the returned entry is managed by camera framework. Do not
179 * attempt to free it.</p>
180 *
181 * @param metadata the {@link ACameraMetadata} of interest.
182 * @param tag the tag value of the camera metadata entry to be get.
183 * @param entry the output {@link ACameraMetadata_const_entry} will be filled here if the method
184 * call succeeeds.
185 *
186 * @return <ul>
187 * <li>{@link ACAMERA_OK} if the method call succeeds.</li>
188 * <li>{@link ACAMERA_ERROR_INVALID_PARAMETER} if metadata or entry is NULL.</li>
189 * <li>{@link ACAMERA_ERROR_METADATA_NOT_FOUND} if input metadata does not contain an entry
190 * of input tag value.</li></ul>
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800191 */
192camera_status_t ACameraMetadata_getConstEntry(
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700193 const ACameraMetadata* metadata, uint32_t tag, /*out*/ACameraMetadata_const_entry* entry);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800194
195/**
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700196 * List all the entry tags in input {@link ACameraMetadata}.
197 *
198 * @param metadata the {@link ACameraMetadata} of interest.
199 * @param numEntries number of metadata entries in input {@link ACameraMetadata}
200 * @param tags the tag values of the metadata entries. Length of tags is returned in numEntries
201 * argument. The memory is managed by ACameraMetadata itself and must NOT be free/delete
202 * by application. Do NOT access tags after calling ACameraMetadata_free.
203 *
204 * @return <ul>
205 * <li>{@link ACAMERA_OK} if the method call succeeds.</li>
206 * <li>{@link ACAMERA_ERROR_INVALID_PARAMETER} if metadata, numEntries or tags is NULL.</li>
207 * <li>{@link ACAMERA_ERROR_UNKNOWN} if the method fails for some other reasons.</li></ul>
208 */
209camera_status_t ACameraMetadata_getAllTags(
210 const ACameraMetadata* metadata, /*out*/int32_t* numEntries, /*out*/const uint32_t** tags);
211
212/**
213 * Create a copy of input {@link ACameraMetadata}.
214 *
215 * <p>The returned ACameraMetadata must be freed by the application by {@link ACameraMetadata_free}
216 * after application is done using it.</p>
217 *
218 * @param src the input {@link ACameraMetadata} to be copied.
219 *
220 * @return a valid ACameraMetadata pointer or NULL if the input metadata cannot be copied.
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800221 */
222ACameraMetadata* ACameraMetadata_copy(const ACameraMetadata* src);
223
224/**
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700225 * Free a {@link ACameraMetadata} structure.
226 *
227 * @param metadata the {@link ACameraMetadata} to be freed.
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800228 */
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700229void ACameraMetadata_free(ACameraMetadata* metadata);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800230
Dan Albertd7973ba2016-09-14 12:35:50 -0700231#endif /* __ANDROID_API__ >= 24 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800232
Dan Albertd7973ba2016-09-14 12:35:50 -0700233__END_DECLS
234
235#endif /* _NDK_CAMERA_METADATA_H */
Yin-Chia Yeh3e49be12016-04-12 16:00:33 -0700236
237/** @} */