blob: 9ddfd8156eaa8ea9ba61c1745b2d4d3571ca5682 [file] [log] [blame]
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +01001/*
Biswarup Pal6152a302023-12-19 12:44:09 +00002 * Copyright 2023 The Android Open Source Project
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +01003 *
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
Jan Sebechlebsky4ce32082024-02-14 16:02:11 +010017#ifndef ANDROID_COMPANION_VIRTUALCAMERA_METADATAUTIL_H
18#define ANDROID_COMPANION_VIRTUALCAMERA_METADATAUTIL_H
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +010019
20#include <chrono>
21#include <cstdint>
22#include <map>
23#include <memory>
24#include <variant>
25#include <vector>
26
27#include "aidl/android/hardware/camera/device/CameraMetadata.h"
28#include "system/camera_metadata.h"
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +010029#include "util/Util.h"
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +010030
31namespace android {
32namespace companion {
33namespace virtualcamera {
34
35// Convenience builder for the
36// aidl::android::hardware::camera::device::CameraMetadata.
37//
38// Calling the same builder setter multiple will overwrite the value.
39// This class is not thread-safe.
40class MetadataBuilder {
41 public:
42 struct StreamConfiguration {
43 int32_t width = 0;
44 int32_t height = 0;
45 int32_t format = 0;
46 // Minimal frame duration - corresponds to maximal FPS for given format.
47 // See ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS in CameraMetadataTag.aidl.
Biswarup Pal6152a302023-12-19 12:44:09 +000048 std::chrono::nanoseconds minFrameDuration{0};
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +010049 // Minimal stall duration.
50 // See ANDROID_SCALER_AVAILABLE_STALL_DURATIONS in CameraMetadataTag.aidl.
51 std::chrono::nanoseconds minStallDuration{0};
52 };
53
54 struct ControlRegion {
55 int32_t x0 = 0;
56 int32_t y0 = 0;
57 int32_t x1 = 0;
58 int32_t y1 = 0;
59 int32_t weight = 0;
60 };
61
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +010062 struct FpsRange {
63 int32_t minFps;
64 int32_t maxFps;
65
66 bool operator<(const FpsRange& other) const {
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +010067 return maxFps == other.maxFps ? minFps < other.minFps
68 : maxFps < other.maxFps;
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +010069 }
70 };
71
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +010072 MetadataBuilder() = default;
73 ~MetadataBuilder() = default;
74
75 // See ANDROID_INFO_SUPPORTED_HARDWARE_LEVEL in CameraMetadataTag.aidl.
76 MetadataBuilder& setSupportedHardwareLevel(
77 camera_metadata_enum_android_info_supported_hardware_level_t hwLevel);
78
79 // Whether this camera device has a flash unit
80 // See ANDROID_FLASH_INFO_AVAILABLE in CameraMetadataTag.aidl.
81 MetadataBuilder& setFlashAvailable(bool flashAvailable);
82
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +010083 // See FLASH_STATE in CaptureResult.java.
84 MetadataBuilder& setFlashState(
85 camera_metadata_enum_android_flash_state_t flashState);
86
87 // See FLASH_MODE in CaptureRequest.java.
88 MetadataBuilder& setFlashMode(
89 camera_metadata_enum_android_flash_mode_t flashMode);
90
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +010091 // See ANDROID_LENS_FACING in CameraMetadataTag.aidl.
92 MetadataBuilder& setLensFacing(
93 camera_metadata_enum_android_lens_facing lensFacing);
94
Jan Sebechlebskya984ffb2024-02-01 09:12:37 +010095 // See ANDROID_SENSOR_READOUT_TIMESTAMP in CameraMetadataTag.aidl.
96 MetadataBuilder& setSensorReadoutTimestamp(
97 camera_metadata_enum_android_sensor_readout_timestamp_t
98 sensorReadoutTimestamp);
99
Biswarup Pal8ad8bc52024-02-08 13:41:44 +0000100 // See ANDROID_LENS_INFO_AVAILABLE_FOCAL_LENGTHS in CameraMetadataTag.aidl.
Jan Sebechlebsky4ce32082024-02-14 16:02:11 +0100101 MetadataBuilder& setAvailableFocalLengths(
102 const std::vector<float>& focalLengths);
Biswarup Pal8ad8bc52024-02-08 13:41:44 +0000103
104 // See ANDROID_LENS_FOCAL_LENGTH in CameraMetadataTag.aidl.
Biswarup Pald9be04d2024-01-31 14:35:15 +0000105 MetadataBuilder& setFocalLength(float focalLength);
106
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100107 // See ANDROID_SENSOR_ORIENTATION in CameraMetadataTag.aidl.
108 MetadataBuilder& setSensorOrientation(int32_t sensorOrientation);
109
110 // Time at start of exposure of first row of the image
111 // sensor active array, in nanoseconds.
112 //
113 // See ANDROID_SENSOR_TIMESTAMP in CameraMetadataTag.aidl.
114 MetadataBuilder& setSensorTimestamp(std::chrono::nanoseconds timestamp);
115
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +0100116 // See SENSOR_INFO_TIMESTAMP_SOURCE in CameraCharacteristic.java.
117 MetadataBuilder& setSensorTimestampSource(
118 camera_metadata_enum_android_sensor_info_timestamp_source_t timestampSource);
119
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100120 // See ANDROID_SENSOR_INFO_ACTIVE_ARRAY_SIZE in CameraMetadataTag.aidl.
121 MetadataBuilder& setSensorActiveArraySize(int x0, int y0, int x1, int y1);
122
Biswarup Pald9be04d2024-01-31 14:35:15 +0000123 // See ANDROID_SENSOR_INFO_PIXEL_ARRAY_SIZE in CameraMetadataTag.aidl.
124 MetadataBuilder& setSensorPixelArraySize(int width, int height);
125
126 // See ANDROID_SENSOR_INFO_PHYSICAL_SIZE in CameraMetadataTag.aidl.
127 MetadataBuilder& setSensorPhysicalSize(float width, float height);
128
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100129 // See ANDROID_STATISTICS_FACE_DETECT_MODE in CameraMetadataTag.aidl.
130 MetadataBuilder& setAvailableFaceDetectModes(
131 const std::vector<camera_metadata_enum_android_statistics_face_detect_mode_t>&
132 faceDetectMode);
133
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +0100134 // See SENSOR_AVAILABLE_TEST_PATTERN_MODES in CameraCharacteristics.java.
135 MetadataBuilder& setAvailableTestPatternModes(
136 const std::vector<camera_metadata_enum_android_sensor_test_pattern_mode>&
137 testPatternModes);
138
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100139 // See ANDROID_STATISTICS_FACE_DETECT_MODE in CaptureRequest.java.
140 MetadataBuilder& setFaceDetectMode(
141 camera_metadata_enum_android_statistics_face_detect_mode_t faceDetectMode);
142
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100143 // Sets available stream configurations along with corresponding minimal frame
144 // durations (corresponding to max fps) and stall durations.
145 //
146 // See ANDROID_SCALER_AVAILABLE_STREAM_CONFIGURATIONS,
147 // ANDROID_SCALER_AVAILABLE_MIN_FRAME_DURATIONS and
148 // ANDROID_SCALER_AVAILABLE_STALL_DURATIONS in CameraMetadataTag.aidl.
149 MetadataBuilder& setAvailableOutputStreamConfigurations(
150 const std::vector<StreamConfiguration>& streamConfigurations);
151
Jan Sebechlebskyb0119fa2023-12-04 10:29:06 +0100152 // See ANDROID_CONTROL_AVAILABLE_MODES in CameraMetadataTag.aidl.
153 MetadataBuilder& setControlAvailableModes(
154 const std::vector<camera_metadata_enum_android_control_mode_t>&
155 availableModes);
156
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100157 // See ANDROID_CONTROL_MODE in CaptureRequest.java.
158 MetadataBuilder& setControlMode(
159 camera_metadata_enum_android_control_mode_t mode);
160
Jan Sebechlebsky4425a732024-01-31 11:31:54 +0100161 // See ANDROID_CONTROL_AVAILABLE_SCENE_MODES in CameraMetadataTag.aidl.
162 MetadataBuilder& setControlAvailableSceneModes(
163 const std::vector<camera_metadata_enum_android_control_scene_mode>&
164 availableSceneModes);
165
166 // See ANDROID_CONTROL_AVAILABLE_EFFECTS in CameraMetadataTag.aidl.
167 MetadataBuilder& setControlAvailableEffects(
168 const std::vector<camera_metadata_enum_android_control_effect_mode>&
169 availableEffects);
170
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +0100171 // See CONTROL_EFFECT_MODE in CaptureRequest.java.
172 MetadataBuilder& setControlEffectMode(
173 camera_metadata_enum_android_control_effect_mode_t effectMode);
174
175 // See ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES
176 MetadataBuilder& setControlAvailableVideoStabilizationModes(
177 const std::vector<
178 camera_metadata_enum_android_control_video_stabilization_mode_t>&
179 videoStabilizationModes);
180
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100181 // See CONTROL_AE_AVAILABLE_ANTIBANDING_MODES in CameraCharacteristics.java.
182 MetadataBuilder& setControlAeAvailableAntibandingModes(
183 const std::vector<camera_metadata_enum_android_control_ae_antibanding_mode_t>&
184 antibandingModes);
185
186 // See CONTROL_AE_ANTIBANDING_MODE in CaptureRequest.java.
187 MetadataBuilder& setControlAeAntibandingMode(
188 camera_metadata_enum_android_control_ae_antibanding_mode_t antibandingMode);
189
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100190 // See ANDROID_CONTROL_AE_COMPENSATION_RANGE in CameraMetadataTag.aidl.
191 MetadataBuilder& setControlAeCompensationRange(int32_t min, int32_t max);
192
193 // See ANDROID_CONTROL_AE_COMPENSATION_STEP in CameraMetadataTag.aidl.
194 MetadataBuilder& setControlAeCompensationStep(camera_metadata_rational step);
195
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100196 // See ANDROID_CONTROL_AE_EXPOSURE_COMPENSATION in CameraMetadataTag.aidl.
197 MetadataBuilder& setControlAeExposureCompensation(int32_t exposureCompensation);
198
199 // See ANDROID_CONTROL_AE_AVAILABLE_MODES in CameraCharacteristics.java.
200 MetadataBuilder& setControlAeAvailableModes(
201 const std::vector<camera_metadata_enum_android_control_ae_mode_t>& modes);
202
203 // See ANDROID_CONTROL_AE_MODE in CaptureRequest.java.
204 MetadataBuilder& setControlAeMode(
205 camera_metadata_enum_android_control_ae_mode_t step);
206
207 // See ANDROID_CONTROL_AE_PRECAPTURE_TRIGGER in CaptureRequest.java.
208 MetadataBuilder& setControlAePrecaptureTrigger(
209 camera_metadata_enum_android_control_ae_precapture_trigger_t trigger);
210
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100211 // See ANDROID_CONTROL_AF_AVAILABLE_MODES in CameraMetadataTag.aidl.
212 MetadataBuilder& setControlAfAvailableModes(
213 const std::vector<camera_metadata_enum_android_control_af_mode_t>&
214 availableModes);
215
216 // See ANDROID_CONTROL_AF_MODE in CameraMetadataTag.aidl.
217 MetadataBuilder& setControlAfMode(
218 const camera_metadata_enum_android_control_af_mode_t mode);
219
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100220 // See ANDROID_CONTROL_AF_TRIGGER_MODE in CameraMetadataTag.aidl.
221 MetadataBuilder& setControlAfTrigger(
222 const camera_metadata_enum_android_control_af_trigger_t trigger);
223
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100224 // See ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES in CameraMetadataTag.aidl.
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100225 MetadataBuilder& setControlAeAvailableFpsRanges(
226 const std::vector<FpsRange>& fpsRanges);
227
228 // See ANDROID_CONTROL_AE_TARGET_FPS_RANGE in CaptureRequest.java.
229 MetadataBuilder& setControlAeTargetFpsRange(int32_t min, int32_t max);
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100230
231 // See ANDROID_CONTROL_CAPTURE_INTENT in CameraMetadataTag.aidl.
232 MetadataBuilder& setControlCaptureIntent(
233 camera_metadata_enum_android_control_capture_intent_t intent);
234
235 // See ANDROID_CONTROL_MAX_REGIONS in CameraMetadataTag.aidl.
236 MetadataBuilder& setControlMaxRegions(int32_t maxAeRegions,
237 int32_t maxAwbRegions,
238 int32_t maxAfRegions);
239
Jan Sebechlebsky4425a732024-01-31 11:31:54 +0100240 // See ANDROID_CONTROL_AWB_AVAILABLE_MODES in CameraMetadataTag.aidl.
241 MetadataBuilder& setControlAvailableAwbModes(
242 const std::vector<camera_metadata_enum_android_control_awb_mode>& awbModes);
243
Jan Sebechlebskyc3e1a632024-02-06 14:19:05 +0100244 // See ANDROID_CONTROL_AWB_AVAILABLE_MODE in CaptureRequest.java.
245 MetadataBuilder& setControlAwbMode(
246 camera_metadata_enum_android_control_awb_mode awb);
247
Jan Sebechlebsky4425a732024-01-31 11:31:54 +0100248 // See CONTROL_AWB_LOCK_AVAILABLE in CameraMetadataTag.aidl.
249 MetadataBuilder& setControlAwbLockAvailable(bool awbLockAvailable);
250
251 // See CONTROL_AE_LOCK_AVAILABLE in CameraMetadataTag.aidl.
252 MetadataBuilder& setControlAeLockAvailable(bool aeLockAvailable);
253
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100254 // See ANDROID_CONTROL_AE_REGIONS in CameraMetadataTag.aidl.
255 MetadataBuilder& setControlAeRegions(
256 const std::vector<ControlRegion>& aeRegions);
257
258 // See ANDROID_CONTROL_AWB_REGIONS in CameraMetadataTag.aidl.
259 MetadataBuilder& setControlAwbRegions(
260 const std::vector<ControlRegion>& awbRegions);
261
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +0100262 // See ANDROID_SCALER_CROP_REGION in CaptureRequest.java.
263 MetadataBuilder& setCropRegion(int32_t x, int32_t y, int32_t width,
264 int32_t height);
265
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100266 // See ANDROID_CONTROL_AF_REGIONS in CameraMetadataTag.aidl.
267 MetadataBuilder& setControlAfRegions(
268 const std::vector<ControlRegion>& afRegions);
269
270 // The size of the compressed JPEG image, in bytes.
271 //
272 // See ANDROID_JPEG_SIZE in CameraMetadataTag.aidl.
273 MetadataBuilder& setMaxJpegSize(int32_t size);
274
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +0100275 // See SENSOR_INFO_MAX_FRAME_DURATION in CameraCharacteristic.java.
276 MetadataBuilder& setMaxFrameDuration(std::chrono::nanoseconds duration);
277
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +0100278 // See JPEG_AVAILABLE_THUMBNAIL_SIZES in CameraCharacteristic.java.
279 MetadataBuilder& setJpegAvailableThumbnailSizes(
280 const std::vector<Resolution>& thumbnailSizes);
281
Jan Sebechlebsky4ce32082024-02-14 16:02:11 +0100282 // See JPEG_QUALITY in CaptureRequest.java.
283 MetadataBuilder& setJpegQuality(uint8_t quality);
284
285 // See JPEG_THUMBNAIL_SIZE in CaptureRequest.java.
286 MetadataBuilder& setJpegThumbnailSize(int width, int height);
287
288 // See JPEG_THUMBNAIL_QUALITY in CaptureRequest.java.
289 MetadataBuilder& setJpegThumbnailQuality(uint8_t quality);
290
Jan Sebechlebsky8ae23592024-02-02 16:08:18 +0100291 // The maximum numbers of different types of output streams
292 // that can be configured and used simultaneously by a camera device.
293 //
294 // See ANDROID_REQUEST_MAX_NUM_OUTPUT_STREAMS in CameraMetadataTag.aidl.
295 MetadataBuilder& setMaxNumberOutputStreams(int32_t maxRawStreams,
296 int32_t maxProcessedStreams,
297 int32_t maxStallStreams);
298
Jan Sebechlebsky4425a732024-01-31 11:31:54 +0100299 // See ANDROID_SYNC_MAX_LATENCY in CameraMetadataTag.aidl.
300 MetadataBuilder& setSyncMaxLatency(
301 camera_metadata_enum_android_sync_max_latency setSyncMaxLatency);
302
Jan Sebechlebskybb01c1d2024-02-12 11:41:37 +0100303 // See REQUEST_PIPELINE_MAX_DEPTH in CameraCharacteristic.java.
304 MetadataBuilder& setPipelineMaxDepth(uint8_t maxDepth);
305
306 // See REQUEST_PIPELINE_DEPTH in CaptureResult.java.
307 MetadataBuilder& setPipelineDepth(uint8_t depth);
308
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100309 // See ANDROID_SCALER_AVAILABLE_MAX_DIGITAL_ZOOM in CameraMetadataTag.aidl.
310 MetadataBuilder& setAvailableMaxDigitalZoom(const float maxZoom);
311
Jan Sebechlebsky6ab07fe2023-12-05 15:23:34 +0100312 // See ANDROID_CONTROL_ZOOM_RATIO_RANGE in CameraMetadataTag.aidl.
313 MetadataBuilder& setControlZoomRatioRange(float min, float max);
314
Jan Sebechlebsky4425a732024-01-31 11:31:54 +0100315 // See ANDROID_REQUEST_AVAILABLE_CAPABILITIES in CameraMetadataTag.aidl.
316 MetadataBuilder& setAvailableRequestCapabilities(
317 const std::vector<
318 camera_metadata_enum_android_request_available_capabilities_t>&
319 requestCapabilities);
320
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100321 // A list of all keys that the camera device has available to use with
322 // CaptureRequest.
323 //
324 // See ANDROID_REQUEST_AVAILABLE_REQUEST_KEYS in CameraMetadataTag.aidl.
325 MetadataBuilder& setAvailableRequestKeys(const std::vector<int32_t>& keys);
326
327 // A list of all keys that the camera device has available to use with
328 // CaptureResult.
329 //
330 // See ANDROID_RESULT_AVAILABLE_REQUEST_KEYS in CameraMetadataTag.aidl.
331 MetadataBuilder& setAvailableResultKeys(const std::vector<int32_t>& keys);
332
333 // See ANDROID_REQUEST_AVAILABLE_CAPABILITIES in CameraMetadataTag.aidl.
334 MetadataBuilder& setAvailableCapabilities(
335 const std::vector<
336 camera_metadata_enum_android_request_available_capabilities_t>&
337 capabilities);
338
339 // A list of all keys that the camera device has available to use.
340 //
341 // See ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS in CameraMetadataTag.aidl.
342 MetadataBuilder& setAvailableCharacteristicKeys(
343 const std::vector<camera_metadata_tag_t>& keys);
344
345 // Extends metadata with ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +0100346 // containing all set tags.
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100347 MetadataBuilder& setAvailableCharacteristicKeys();
348
349 // Build CameraMetadata instance.
350 //
351 // Returns nullptr in case something went wrong.
352 std::unique_ptr<::aidl::android::hardware::camera::device::CameraMetadata>
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +0100353 build();
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100354
355 private:
356 // Maps metadata tags to vectors of values for the given tag.
357 std::map<camera_metadata_tag_t,
358 std::variant<std::vector<int64_t>, std::vector<int32_t>,
359 std::vector<uint8_t>, std::vector<float>,
360 std::vector<camera_metadata_rational_t>>>
361 mEntryMap;
Jan Sebechlebskyad8d35f2024-02-05 11:58:59 +0100362 // Extend metadata with ANDROID_REQUEST_AVAILABLE_CHARACTERISTICS_KEYS.
363 bool mExtendWithAvailableCharacteristicsKeys = false;
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100364};
365
Jan Sebechlebsky4ce32082024-02-14 16:02:11 +0100366// Returns JPEG_QUALITY from metadata, or nullopt if the key is not present.
367std::optional<int32_t> getJpegQuality(
368 const aidl::android::hardware::camera::device::CameraMetadata& metadata);
369
370// Returns JPEG_THUMBNAIL_SIZE from metadata, or nullopt if the key is not present.
371std::optional<Resolution> getJpegThumbnailSize(
372 const aidl::android::hardware::camera::device::CameraMetadata& metadata);
373
374// Returns JPEG_THUMBNAIL_QUALITY from metadata, or nullopt if the key is not present.
375std::optional<int32_t> getJpegThumbnailQuality(
376 const aidl::android::hardware::camera::device::CameraMetadata& metadata);
377
378// Returns JPEG_AVAILABLE_THUMBNAIL_SIZES from metadata, or nullopt if the key
379// is not present.
380std::vector<Resolution> getJpegAvailableThumbnailSizes(
381 const aidl::android::hardware::camera::device::CameraMetadata& metadata);
382
Jan Sebechlebsky5cb39962023-11-22 17:33:07 +0100383} // namespace virtualcamera
384} // namespace companion
385} // namespace android
386
Jan Sebechlebsky4ce32082024-02-14 16:02:11 +0100387#endif // ANDROID_COMPANION_VIRTUALCAMERA_METADATAUTIL_H