blob: 58e0c6f822f4bb79b468c397a0cea201c712c885 [file] [log] [blame]
Iliyan Malchev66ea3572011-05-01 14:05:30 -07001/*
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/cdefs.h>
22#include <sys/types.h>
23#include <cutils/native_handle.h>
24#include <hardware/hardware.h>
25#include <hardware/gralloc.h>
26
27__BEGIN_DECLS
28
29/**
30 * A set of bit masks for specifying how the received preview frames are
31 * handled before the previewCallback() call.
32 *
33 * The least significant 3 bits of an "int" value are used for this purpose:
34 *
35 * ..... 0 0 0
36 * ^ ^ ^
37 * | | |---------> determine whether the callback is enabled or not
38 * | |-----------> determine whether the callback is one-shot or not
39 * |-------------> determine whether the frame is copied out or not
40 *
41 * WARNING: When a frame is sent directly without copying, it is the frame
42 * receiver's responsiblity to make sure that the frame data won't get
43 * corrupted by subsequent preview frames filled by the camera. This flag is
44 * recommended only when copying out data brings significant performance price
45 * and the handling/processing of the received frame data is always faster than
46 * the preview frame rate so that data corruption won't occur.
47 *
48 * For instance,
49 * 1. 0x00 disables the callback. In this case, copy out and one shot bits
50 * are ignored.
51 * 2. 0x01 enables a callback without copying out the received frames. A
52 * typical use case is the Camcorder application to avoid making costly
53 * frame copies.
54 * 3. 0x05 is enabling a callback with frame copied out repeatedly. A typical
55 * use case is the Camera application.
56 * 4. 0x07 is enabling a callback with frame copied out only once. A typical
57 * use case is the Barcode scanner application.
58 */
59
60enum {
61 CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK = 0x01,
62 CAMERA_FRAME_CALLBACK_FLAG_ONE_SHOT_MASK = 0x02,
63 CAMERA_FRAME_CALLBACK_FLAG_COPY_OUT_MASK = 0x04,
64 /** Typical use cases */
65 CAMERA_FRAME_CALLBACK_FLAG_NOOP = 0x00,
66 CAMERA_FRAME_CALLBACK_FLAG_CAMCORDER = 0x01,
67 CAMERA_FRAME_CALLBACK_FLAG_CAMERA = 0x05,
68 CAMERA_FRAME_CALLBACK_FLAG_BARCODE_SCANNER = 0x07
69};
70
71/** msgType in notifyCallback and dataCallback functions */
72enum {
73 CAMERA_MSG_ERROR = 0x0001,
74 CAMERA_MSG_SHUTTER = 0x0002,
75 CAMERA_MSG_FOCUS = 0x0004,
76 CAMERA_MSG_ZOOM = 0x0008,
77 CAMERA_MSG_PREVIEW_FRAME = 0x0010,
78 CAMERA_MSG_VIDEO_FRAME = 0x0020,
79 CAMERA_MSG_POSTVIEW_FRAME = 0x0040,
80 CAMERA_MSG_RAW_IMAGE = 0x0080,
81 CAMERA_MSG_COMPRESSED_IMAGE = 0x0100,
82 CAMERA_MSG_RAW_IMAGE_NOTIFY = 0x0200,
83 CAMERA_MSG_ALL_MSGS = 0xFFFF
84};
85
86/** cmdType in sendCommand functions */
87enum {
88 CAMERA_CMD_START_SMOOTH_ZOOM = 1,
89 CAMERA_CMD_STOP_SMOOTH_ZOOM = 2,
90 /** Set the clockwise rotation of preview display (setPreviewDisplay) in
91 * degrees. This affects the preview frames and the picture displayed after
92 * snapshot. This method is useful for portrait mode applications. Note
93 * that preview display of front-facing cameras is flipped horizontally
94 * before the rotation, that is, the image is reflected along the central
95 * vertical axis of the camera sensor. So the users can see themselves as
96 * looking into a mirror.
97 *
98 * This does not affect the order of byte array of
99 * CAMERA_MSG_PREVIEW_FRAME, CAMERA_MSG_VIDEO_FRAME,
100 * CAMERA_MSG_POSTVIEW_FRAME, CAMERA_MSG_RAW_IMAGE, or
101 * CAMERA_MSG_COMPRESSED_IMAGE. This is not allowed to be set during
102 * preview
103 */
104 CAMERA_CMD_SET_DISPLAY_ORIENTATION = 3,
105
106 /** cmdType to disable/enable shutter sound. In sendCommand passing arg1 =
107 * 0 will disable, while passing arg1 = 1 will enable the shutter sound.
108 */
109 CAMERA_CMD_ENABLE_SHUTTER_SOUND = 4,
110
111 /* cmdType to play recording sound */
112 CAMERA_CMD_PLAY_RECORDING_SOUND = 5,
113};
114
115/** camera fatal errors */
116enum {
117 CAMERA_ERROR_UNKNOWN = 1,
118 CAMERA_ERROR_SERVER_DIED = 100
119};
120
121enum {
122 CAMERA_FACING_BACK = 0, /** The facing of the camera is opposite to that of
123 * the screen. */
124 CAMERA_FACING_FRONT = 1 /** The facing of the camera is the same as that of
125 * the screen. */
126};
127
128__END_DECLS
129
130#endif /* SYSTEM_CORE_INCLUDE_ANDROID_CAMERA_H */