blob: c67620174cc4b139ccca899729c0603c9f8ea647 [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001/*
2 * Copyright (C) 2011 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 SYSTEM_CORE_INCLUDE_ANDROID_CAMERA_H
18#define SYSTEM_CORE_INCLUDE_ANDROID_CAMERA_H
19
20#include <stdint.h>
21#include <sys/types.h>
22#include <cutils/native_handle.h>
23#include <hardware/hardware.h>
24#include <hardware/gralloc.h>
25
26#ifdef __cplusplus
27extern "C" {
28#endif
29
30/**
31 * A set of bit masks for specifying how the received preview frames are
32 * handled before the previewCallback() call.
33 *
34 * The least significant 3 bits of an "int" value are used for this purpose:
35 *
36 * ..... 0 0 0
37 * ^ ^ ^
38 * | | |---------> determine whether the callback is enabled or not
39 * | |-----------> determine whether the callback is one-shot or not
40 * |-------------> determine whether the frame is copied out or not
41 *
42 * WARNING: When a frame is sent directly without copying, it is the frame
43 * receiver's responsiblity to make sure that the frame data won't get
44 * corrupted by subsequent preview frames filled by the camera. This flag is
45 * recommended only when copying out data brings significant performance price
46 * and the handling/processing of the received frame data is always faster than
47 * the preview frame rate so that data corruption won't occur.
48 *
49 * For instance,
50 * 1. 0x00 disables the callback. In this case, copy out and one shot bits
51 * are ignored.
52 * 2. 0x01 enables a callback without copying out the received frames. A
53 * typical use case is the Camcorder application to avoid making costly
54 * frame copies.
55 * 3. 0x05 is enabling a callback with frame copied out repeatedly. A typical
56 * use case is the Camera application.
57 * 4. 0x07 is enabling a callback with frame copied out only once. A typical
58 * use case is the Barcode scanner application.
59 */
60
61enum {
62 CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK = 0x01,
63 CAMERA_FRAME_CALLBACK_FLAG_ONE_SHOT_MASK = 0x02,
64 CAMERA_FRAME_CALLBACK_FLAG_COPY_OUT_MASK = 0x04,
65 /** Typical use cases */
66 CAMERA_FRAME_CALLBACK_FLAG_NOOP = 0x00,
67 CAMERA_FRAME_CALLBACK_FLAG_CAMCORDER = 0x01,
68 CAMERA_FRAME_CALLBACK_FLAG_CAMERA = 0x05,
69 CAMERA_FRAME_CALLBACK_FLAG_BARCODE_SCANNER = 0x07
70};
71
72/** msgType in notifyCallback and dataCallback functions */
73enum {
74 CAMERA_MSG_ERROR = 0x0001, // notifyCallback
75 CAMERA_MSG_SHUTTER = 0x0002, // notifyCallback
76 CAMERA_MSG_FOCUS = 0x0004, // notifyCallback
77 CAMERA_MSG_ZOOM = 0x0008, // notifyCallback
78 CAMERA_MSG_PREVIEW_FRAME = 0x0010, // dataCallback
79 CAMERA_MSG_VIDEO_FRAME = 0x0020, // data_timestamp_callback
80 CAMERA_MSG_POSTVIEW_FRAME = 0x0040, // dataCallback
81 CAMERA_MSG_RAW_IMAGE = 0x0080, // dataCallback
82 CAMERA_MSG_COMPRESSED_IMAGE = 0x0100, // dataCallback
83 CAMERA_MSG_RAW_IMAGE_NOTIFY = 0x0200, // dataCallback
84 // Preview frame metadata. This can be combined with
85 // CAMERA_MSG_PREVIEW_FRAME in dataCallback. For example, the apps can
86 // request FRAME and METADATA. Or the apps can request only FRAME or only
87 // METADATA.
88 CAMERA_MSG_PREVIEW_METADATA = 0x0400, // dataCallback
89 // Notify on autofocus start and stop. This is useful in continuous
90 // autofocus - FOCUS_MODE_CONTINUOUS_VIDEO and FOCUS_MODE_CONTINUOUS_PICTURE.
91 CAMERA_MSG_FOCUS_MOVE = 0x0800, // notifyCallback
92 CAMERA_MSG_ALL_MSGS = 0xFFFF
93};
94
95/** cmdType in sendCommand functions */
96enum {
97 CAMERA_CMD_START_SMOOTH_ZOOM = 1,
98 CAMERA_CMD_STOP_SMOOTH_ZOOM = 2,
99
100 /**
101 * Set the clockwise rotation of preview display (setPreviewDisplay) in
102 * degrees. This affects the preview frames and the picture displayed after
103 * snapshot. This method is useful for portrait mode applications. Note
104 * that preview display of front-facing cameras is flipped horizontally
105 * before the rotation, that is, the image is reflected along the central
106 * vertical axis of the camera sensor. So the users can see themselves as
107 * looking into a mirror.
108 *
109 * This does not affect the order of byte array of
110 * CAMERA_MSG_PREVIEW_FRAME, CAMERA_MSG_VIDEO_FRAME,
111 * CAMERA_MSG_POSTVIEW_FRAME, CAMERA_MSG_RAW_IMAGE, or
112 * CAMERA_MSG_COMPRESSED_IMAGE. This is allowed to be set during preview
113 * since API level 14.
114 */
115 CAMERA_CMD_SET_DISPLAY_ORIENTATION = 3,
116
117 /**
118 * cmdType to disable/enable shutter sound. In sendCommand passing arg1 =
119 * 0 will disable, while passing arg1 = 1 will enable the shutter sound.
120 */
121 CAMERA_CMD_ENABLE_SHUTTER_SOUND = 4,
122
123 /* cmdType to play recording sound */
124 CAMERA_CMD_PLAY_RECORDING_SOUND = 5,
125
126 /**
127 * Start the face detection. This should be called after preview is started.
128 * The camera will notify the listener of CAMERA_MSG_FACE and the detected
129 * faces in the preview frame. The detected faces may be the same as the
130 * previous ones. Apps should call CAMERA_CMD_STOP_FACE_DETECTION to stop
131 * the face detection. This method is supported if CameraParameters
132 * KEY_MAX_NUM_HW_DETECTED_FACES or KEY_MAX_NUM_SW_DETECTED_FACES is
133 * bigger than 0. Hardware and software face detection should not be running
134 * at the same time. If the face detection has started, apps should not send
135 * this again.
136 *
137 * In hardware face detection mode, CameraParameters KEY_WHITE_BALANCE,
138 * KEY_FOCUS_AREAS and KEY_METERING_AREAS have no effect.
139 *
140 * arg1 is the face detection type. It can be CAMERA_FACE_DETECTION_HW or
141 * CAMERA_FACE_DETECTION_SW. If the type of face detection requested is not
142 * supported, the HAL must return BAD_VALUE.
143 */
144 CAMERA_CMD_START_FACE_DETECTION = 6,
145
146 /**
147 * Stop the face detection.
148 */
149 CAMERA_CMD_STOP_FACE_DETECTION = 7,
150
151 /**
152 * Enable/disable focus move callback (CAMERA_MSG_FOCUS_MOVE). Passing
153 * arg1 = 0 will disable, while passing arg1 = 1 will enable the callback.
154 */
155 CAMERA_CMD_ENABLE_FOCUS_MOVE_MSG = 8,
156
157 /**
158 * Ping camera service to see if camera hardware is released.
159 *
160 * When any camera method returns error, the client can use ping command
161 * to see if the camera has been taken away by other clients. If the result
162 * is NO_ERROR, it means the camera hardware is not released. If the result
163 * is not NO_ERROR, the camera has been released and the existing client
164 * can silently finish itself or show a dialog.
165 */
166 CAMERA_CMD_PING = 9,
167
168 /**
169 * Configure the number of video buffers used for recording. The intended
170 * video buffer count for recording is passed as arg1, which must be
171 * greater than 0. This command must be sent before recording is started.
172 * This command returns INVALID_OPERATION error if it is sent after video
173 * recording is started, or the command is not supported at all. This
174 * command also returns a BAD_VALUE error if the intended video buffer
175 * count is non-positive or too big to be realized.
176 */
177 CAMERA_CMD_SET_VIDEO_BUFFER_COUNT = 10,
178};
179
180/** camera fatal errors */
181enum {
182 CAMERA_ERROR_UNKNOWN = 1,
183 /**
184 * Camera was released because another client has connected to the camera.
185 * The original client should call Camera::disconnect immediately after
186 * getting this notification. Otherwise, the camera will be released by
187 * camera service in a short time. The client should not call any method
188 * (except disconnect and sending CAMERA_CMD_PING) after getting this.
189 */
190 CAMERA_ERROR_RELEASED = 2,
191 CAMERA_ERROR_SERVER_DIED = 100
192};
193
194enum {
195 /** The facing of the camera is opposite to that of the screen. */
196 CAMERA_FACING_BACK = 0,
197 /** The facing of the camera is the same as that of the screen. */
198 CAMERA_FACING_FRONT = 1
199};
200
201enum {
202 /** Hardware face detection. It does not use much CPU. */
203 CAMERA_FACE_DETECTION_HW = 0,
204 /**
205 * Software face detection. It uses some CPU. Applications must use
206 * Camera.setPreviewTexture for preview in this mode.
207 */
208 CAMERA_FACE_DETECTION_SW = 1
209};
210
211/**
212 * The information of a face from camera face detection.
213 */
214typedef struct camera_face {
215 /**
216 * Bounds of the face [left, top, right, bottom]. (-1000, -1000) represents
217 * the top-left of the camera field of view, and (1000, 1000) represents the
218 * bottom-right of the field of view. The width and height cannot be 0 or
219 * negative. This is supported by both hardware and software face detection.
220 *
221 * The direction is relative to the sensor orientation, that is, what the
222 * sensor sees. The direction is not affected by the rotation or mirroring
223 * of CAMERA_CMD_SET_DISPLAY_ORIENTATION.
224 */
225 int32_t rect[4];
226
227 /**
228 * The confidence level of the face. The range is 1 to 100. 100 is the
229 * highest confidence. This is supported by both hardware and software
230 * face detection.
231 */
232 int32_t score;
233
234 /**
235 * An unique id per face while the face is visible to the tracker. If
236 * the face leaves the field-of-view and comes back, it will get a new
237 * id. If the value is 0, id is not supported.
238 */
239 int32_t id;
240
241 /**
242 * The coordinates of the center of the left eye. The range is -1000 to
243 * 1000. -2000, -2000 if this is not supported.
244 */
245 int32_t left_eye[2];
246
247 /**
248 * The coordinates of the center of the right eye. The range is -1000 to
249 * 1000. -2000, -2000 if this is not supported.
250 */
251 int32_t right_eye[2];
252
253 /**
254 * The coordinates of the center of the mouth. The range is -1000 to 1000.
255 * -2000, -2000 if this is not supported.
256 */
257 int32_t mouth[2];
258
259} camera_face_t;
260
261/**
262 * The metadata of the frame data.
263 */
264typedef struct camera_frame_metadata {
265 /**
266 * The number of detected faces in the frame.
267 */
268 int32_t number_of_faces;
269
270 /**
271 * An array of the detected faces. The length is number_of_faces.
272 */
273 camera_face_t *faces;
274} camera_frame_metadata_t;
275
276#ifdef __cplusplus
277}
278#endif
279#endif /* SYSTEM_CORE_INCLUDE_ANDROID_CAMERA_H */