1 /*
2  * Copyright (C) 2019 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 #ifndef ANDROID_SERVERS_ZOOMRATIOMAPPER_H
18 #define ANDROID_SERVERS_ZOOMRATIOMAPPER_H
19 
20 #include <utils/Errors.h>
21 #include <array>
22 
23 #include "camera/CameraMetadata.h"
24 #include "device3/CoordinateMapper.h"
25 
26 namespace android {
27 
28 namespace camera3 {
29 
30 /**
31  * Utilities to convert between the new zoomRatio and existing cropRegion
32  * metadata tags. Note that this class does conversions in 2 scenarios:
33  * - HAL supports zoomRatio and the application uses cropRegion, or
34  * - HAL doesn't support zoomRatio, but the application uses zoomRatio
35  */
36 class ZoomRatioMapper : public CoordinateMapper {
37   public:
38     ZoomRatioMapper() = default;
39     ZoomRatioMapper(const CameraMetadata *deviceInfo,
40             bool supportNativeZoomRatio, bool usePrecorrectArray);
ZoomRatioMapper(const ZoomRatioMapper & other)41     ZoomRatioMapper(const ZoomRatioMapper& other) :
42             mHalSupportsZoomRatio(other.mHalSupportsZoomRatio),
43             mArrayWidth(other.mArrayWidth), mArrayHeight(other.mArrayHeight),
44             mIsValid(other.mIsValid) { initRemappedKeys(); }
45 
46     void initRemappedKeys() override;
47 
48     /**
49      * Initialize request template with valid zoomRatio if necessary.
50      */
51     static status_t initZoomRatioInTemplate(CameraMetadata *request);
52 
53     /**
54      * Override zoomRatio related tags in the static metadata.
55      */
56     static status_t overrideZoomRatioTags(
57             CameraMetadata* deviceInfo, bool* supportNativeZoomRatio);
58 
59     /**
60      * Update capture request to handle both cropRegion and zoomRatio.
61      */
62     status_t updateCaptureRequest(CameraMetadata *request);
63 
64     /**
65      * Update capture result to handle both cropRegion and zoomRatio.
66      */
67     status_t updateCaptureResult(CameraMetadata *request, bool requestedZoomRatioIs1);
68 
69   public: // Visible for testing. Do not use concurently.
70     void scaleCoordinates(int32_t* coordPairs, int coordCount,
71             float scaleRatio, bool clamp, int32_t arrayWidth, int32_t arrayHeight);
72     void scaleRegion(int32_t* region, float scaleRatio,
73             int32_t arrayWidth, int32_t arrayHeight);
74 
isValid()75     bool isValid() { return mIsValid; }
76   private:
77     // const after construction
78     bool mHalSupportsZoomRatio;
79 
80     // active array / pre-correction array dimension for default and maximum
81     // resolution modes.
82     int32_t mArrayWidth, mArrayHeight;
83     int32_t mArrayWidthMaximumResolution, mArrayHeightMaximumResolution;
84 
85     bool mIsValid = false;
86 
87     status_t deriveZoomRatio(const CameraMetadata* metadata, float *zoomRatio, int arrayWidth,
88             int arrayHeight);
89     void scaleRects(int32_t* rects, int rectCount, float scaleRatio, int32_t arrayWidth,
90             int32_t arrayHeight);
91 
92     status_t separateZoomFromCropLocked(CameraMetadata* metadata, bool isResult, int arrayWidth,
93             int arrayHeight);
94     status_t combineZoomAndCropLocked(CameraMetadata* metadata, bool isResult, int arrayWidth,
95             int arrayHeight);
96     status_t getArrayDimensionsToBeUsed(const CameraMetadata *settings, int32_t *arrayWidth,
97             int32_t *arrayHeight);
98 };
99 
100 } // namespace camera3
101 
102 } // namespace android
103 
104 #endif
105