blob: 072bb0249a912d0929e70f30e63912fb9ba8fd2e [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
Yin-Chia Yeh7842b642018-03-06 10:41:19 -080039#include <stdint.h>
Dan Albertd7973ba2016-09-14 12:35:50 -070040#include <sys/cdefs.h>
41
Jiawen Chen9f713e82020-01-15 11:06:13 -050042#ifndef __ANDROID_VNDK__
43#if __ANDROID_API__ >= 30
44#include "jni.h"
45#endif /* __ANDROID_API__ >= 30 */
46#endif /* __ANDROID_VNDK__ */
47
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080048#include "NdkCameraError.h"
49#include "NdkCameraMetadataTags.h"
50
Dan Albertd7973ba2016-09-14 12:35:50 -070051__BEGIN_DECLS
52
Ryan Prichard0c9470c2018-07-19 18:03:48 -070053#if __ANDROID_API__ >= 24
54
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070055/**
56 * ACameraMetadata is opaque type that provides access to read-only camera metadata like camera
57 * characteristics (via {@link ACameraManager_getCameraCharacteristics}) or capture results (via
58 * {@link ACameraCaptureSession_captureCallback_result}).
59 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080060typedef struct ACameraMetadata ACameraMetadata;
61
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070062/**
63 * Possible data types of a metadata entry.
64 *
65 * Keep in sync with system/media/include/system/camera_metadata.h
66 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080067enum {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070068 /// Unsigned 8-bit integer (uint8_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080069 ACAMERA_TYPE_BYTE = 0,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070070 /// Signed 32-bit integer (int32_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080071 ACAMERA_TYPE_INT32 = 1,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070072 /// 32-bit float (float)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080073 ACAMERA_TYPE_FLOAT = 2,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070074 /// Signed 64-bit integer (int64_t)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080075 ACAMERA_TYPE_INT64 = 3,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070076 /// 64-bit float (double)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080077 ACAMERA_TYPE_DOUBLE = 4,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070078 /// A 64-bit fraction (ACameraMetadata_rational)
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080079 ACAMERA_TYPE_RATIONAL = 5,
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070080 /// Number of type fields
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080081 ACAMERA_NUM_TYPES
82};
83
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070084/**
85 * Definition of rational data type in {@link ACameraMetadata}.
86 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080087typedef struct ACameraMetadata_rational {
88 int32_t numerator;
89 int32_t denominator;
90} ACameraMetadata_rational;
91
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070092/**
93 * A single camera metadata entry.
94 *
95 * <p>Each entry is an array of values, though many metadata fields may only have 1 entry in the
96 * array.</p>
97 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080098typedef struct ACameraMetadata_entry {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -070099 /**
100 * The tag identifying the entry.
101 *
102 * <p> It is one of the values defined in {@link NdkCameraMetadataTags.h}, and defines how the
103 * entry should be interpreted and which parts of the API provide it.
104 * See {@link NdkCameraMetadataTags.h} for more details. </p>
105 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800106 uint32_t tag;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700107
108 /**
109 * The data type of this metadata entry.
110 *
111 * <p>Must be one of ACAMERA_TYPE_* enum values defined above. A particular tag always has the
112 * same type.</p>
113 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800114 uint8_t type;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700115
116 /**
117 * Count of elements (NOT count of bytes) in this metadata entry.
118 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800119 uint32_t count;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700120
121 /**
122 * Pointer to the data held in this metadata entry.
123 *
124 * <p>The type field above defines which union member pointer is valid. The count field above
125 * defines the length of the data in number of elements.</p>
126 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800127 union {
128 uint8_t *u8;
129 int32_t *i32;
130 float *f;
131 int64_t *i64;
132 double *d;
133 ACameraMetadata_rational* r;
134 } data;
135} ACameraMetadata_entry;
136
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700137/**
138 * A single read-only camera metadata entry.
139 *
140 * <p>Each entry is an array of values, though many metadata fields may only have 1 entry in the
141 * array.</p>
142 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800143typedef struct ACameraMetadata_const_entry {
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700144 /**
145 * The tag identifying the entry.
146 *
147 * <p> It is one of the values defined in {@link NdkCameraMetadataTags.h}, and defines how the
148 * entry should be interpreted and which parts of the API provide it.
149 * See {@link NdkCameraMetadataTags.h} for more details. </p>
150 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800151 uint32_t tag;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700152
153 /**
154 * The data type of this metadata entry.
155 *
156 * <p>Must be one of ACAMERA_TYPE_* enum values defined above. A particular tag always has the
157 * same type.</p>
158 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800159 uint8_t type;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700160
161 /**
162 * Count of elements (NOT count of bytes) in this metadata entry.
163 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800164 uint32_t count;
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700165
166 /**
167 * Pointer to the data held in this metadata entry.
168 *
169 * <p>The type field above defines which union member pointer is valid. The count field above
170 * defines the length of the data in number of elements.</p>
171 */
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800172 union {
173 const uint8_t *u8;
174 const int32_t *i32;
175 const float *f;
176 const int64_t *i64;
177 const double *d;
178 const ACameraMetadata_rational* r;
179 } data;
180} ACameraMetadata_const_entry;
181
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700182/**
183 * Get a metadata entry from an input {@link ACameraMetadata}.
184 *
185 * <p>The memory of the data field in the returned entry is managed by camera framework. Do not
186 * attempt to free it.</p>
187 *
188 * @param metadata the {@link ACameraMetadata} of interest.
189 * @param tag the tag value of the camera metadata entry to be get.
190 * @param entry the output {@link ACameraMetadata_const_entry} will be filled here if the method
191 * call succeeeds.
192 *
193 * @return <ul>
194 * <li>{@link ACAMERA_OK} if the method call succeeds.</li>
195 * <li>{@link ACAMERA_ERROR_INVALID_PARAMETER} if metadata or entry is NULL.</li>
196 * <li>{@link ACAMERA_ERROR_METADATA_NOT_FOUND} if input metadata does not contain an entry
197 * of input tag value.</li></ul>
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800198 */
199camera_status_t ACameraMetadata_getConstEntry(
Elliott Hughes85a41532018-06-18 13:17:24 -0700200 const ACameraMetadata* metadata,
201 uint32_t tag, /*out*/ACameraMetadata_const_entry* entry) __INTRODUCED_IN(24);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800202
203/**
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700204 * List all the entry tags in input {@link ACameraMetadata}.
205 *
206 * @param metadata the {@link ACameraMetadata} of interest.
207 * @param numEntries number of metadata entries in input {@link ACameraMetadata}
208 * @param tags the tag values of the metadata entries. Length of tags is returned in numEntries
209 * argument. The memory is managed by ACameraMetadata itself and must NOT be free/delete
210 * by application. Do NOT access tags after calling ACameraMetadata_free.
211 *
212 * @return <ul>
213 * <li>{@link ACAMERA_OK} if the method call succeeds.</li>
214 * <li>{@link ACAMERA_ERROR_INVALID_PARAMETER} if metadata, numEntries or tags is NULL.</li>
215 * <li>{@link ACAMERA_ERROR_UNKNOWN} if the method fails for some other reasons.</li></ul>
216 */
217camera_status_t ACameraMetadata_getAllTags(
Elliott Hughes85a41532018-06-18 13:17:24 -0700218 const ACameraMetadata* metadata,
219 /*out*/int32_t* numEntries, /*out*/const uint32_t** tags) __INTRODUCED_IN(24);
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700220
221/**
222 * Create a copy of input {@link ACameraMetadata}.
223 *
224 * <p>The returned ACameraMetadata must be freed by the application by {@link ACameraMetadata_free}
225 * after application is done using it.</p>
226 *
227 * @param src the input {@link ACameraMetadata} to be copied.
228 *
229 * @return a valid ACameraMetadata pointer or NULL if the input metadata cannot be copied.
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800230 */
Elliott Hughes85a41532018-06-18 13:17:24 -0700231ACameraMetadata* ACameraMetadata_copy(const ACameraMetadata* src) __INTRODUCED_IN(24);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800232
233/**
Yin-Chia Yeh1d0955c2016-05-16 01:14:13 -0700234 * Free a {@link ACameraMetadata} structure.
235 *
236 * @param metadata the {@link ACameraMetadata} to be freed.
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800237 */
Elliott Hughes85a41532018-06-18 13:17:24 -0700238void ACameraMetadata_free(ACameraMetadata* metadata) __INTRODUCED_IN(24);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800239
Ryan Prichard0c9470c2018-07-19 18:03:48 -0700240#endif /* __ANDROID_API__ >= 24 */
241
Shuzhen Wang0ff9ae32018-12-05 18:06:12 -0800242#if __ANDROID_API__ >= 29
243
244/**
245 * Helper function to check if a camera is logical multi-camera.
246 *
247 * <p> Check whether a camera device is a logical multi-camera based on its
248 * static metadata. If it is, also returns its physical sub camera Ids.</p>
249 *
250 * @param staticMetadata the static metadata of the camera being checked.
251 * @param numPhysicalCameras returns the number of physical cameras.
252 * @param physicalCameraIds returns the array of physical camera Ids backing this logical
253 * camera device. Note that this pointer is only valid
254 * during the lifetime of the staticMetadata object.
255 *
256 * @return true if this is a logical multi-camera, false otherwise.
257 */
258bool ACameraMetadata_isLogicalMultiCamera(const ACameraMetadata* staticMetadata,
259 /*out*/size_t* numPhysicalCameras, /*out*/const char* const** physicalCameraIds)
260 __INTRODUCED_IN(29);
261
262#endif /* __ANDROID_API__ >= 29 */
263
Jiawen Chen9f713e82020-01-15 11:06:13 -0500264#ifndef __ANDROID_VNDK__
265#if __ANDROID_API__ >= 30
266
267/**
268 * Return a {@link ACameraMetadata} that references the same data as
269 * {@link cameraMetadata}, which is an instance of
270 * {@link android.hardware.camera2.CameraMetadata} (e.g., a
271 * {@link android.hardware.camera2.CameraCharacteristics} or
272 * {@link android.hardware.camera2.CaptureResult}).
273 *
274 * <p>The returned ACameraMetadata must be freed by the application by {@link ACameraMetadata_free}
275 * after application is done using it.</p>
276 *
Eino-Ville Talvalab949b612020-02-06 11:08:41 -0800277 * <p>The ACameraMetadata maintains a reference count to the underlying data, so
278 * it can be used independently of the Java object, and it remains valid even if
279 * the Java metadata is garbage collected.
Jiawen Chen9f713e82020-01-15 11:06:13 -0500280 *
281 * @param env the JNI environment.
282 * @param cameraMetadata the source {@link android.hardware.camera2.CameraMetadata} from which the
283 * returned {@link ACameraMetadata} is a view.
284 *
285 * @return a valid ACameraMetadata pointer or NULL if {@link cameraMetadata} is null or not a valid
286 * instance of {@link android.hardware.camera2.CameraMetadata}.
287 *
288 */
289ACameraMetadata* ACameraMetadata_fromCameraMetadata(JNIEnv* env, jobject cameraMetadata)
290 __INTRODUCED_IN(30);
291
292#endif /* __ANDROID_API__ >= 30 */
293#endif /* __ANDROID_VNDK__ */
294
Dan Albertd7973ba2016-09-14 12:35:50 -0700295__END_DECLS
296
297#endif /* _NDK_CAMERA_METADATA_H */
Yin-Chia Yeh3e49be12016-04-12 16:00:33 -0700298
Eino-Ville Talvalab949b612020-02-06 11:08:41 -0800299/** @} */