blob: c506fb89582c86b38cda8946b7e33f078fb17dc5 [file] [log] [blame]
The Android Open Source Project9066cfe2009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * Copyright (C) 2008 HTC Inc.
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * http://www.apache.org/licenses/LICENSE-2.0
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 */
17
18#ifndef ANDROID_HARDWARE_CAMERA_H
19#define ANDROID_HARDWARE_CAMERA_H
20
Dave Sparks59c1a932009-07-08 15:56:53 -070021#include <utils/Timers.h>
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080022#include <ui/ICameraClient.h>
23
24namespace android {
25
26/*
27 * A set of bit masks for specifying how the received preview frames are
28 * handled before the previewCallback() call.
29 *
30 * The least significant 3 bits of an "int" value are used for this purpose:
31 *
32 * ..... 0 0 0
33 * ^ ^ ^
34 * | | |---------> determine whether the callback is enabled or not
35 * | |-----------> determine whether the callback is one-shot or not
36 * |-------------> determine whether the frame is copied out or not
37 *
38 * WARNING:
39 * When a frame is sent directly without copying, it is the frame receiver's
40 * responsiblity to make sure that the frame data won't get corrupted by
41 * subsequent preview frames filled by the camera. This flag is recommended
42 * only when copying out data brings significant performance price and the
43 * handling/processing of the received frame data is always faster than
44 * the preview frame rate so that data corruption won't occur.
45 *
46 * For instance,
47 * 1. 0x00 disables the callback. In this case, copy out and one shot bits
48 * are ignored.
49 * 2. 0x01 enables a callback without copying out the received frames. A
50 * typical use case is the Camcorder application to avoid making costly
51 * frame copies.
52 * 3. 0x05 is enabling a callback with frame copied out repeatedly. A typical
53 * use case is the Camera application.
54 * 4. 0x07 is enabling a callback with frame copied out only once. A typical use
55 * case is the Barcode scanner application.
56 */
57#define FRAME_CALLBACK_FLAG_ENABLE_MASK 0x01
58#define FRAME_CALLBACK_FLAG_ONE_SHOT_MASK 0x02
59#define FRAME_CALLBACK_FLAG_COPY_OUT_MASK 0x04
60
61// Typical use cases
62#define FRAME_CALLBACK_FLAG_NOOP 0x00
63#define FRAME_CALLBACK_FLAG_CAMCORDER 0x01
64#define FRAME_CALLBACK_FLAG_CAMERA 0x05
65#define FRAME_CALLBACK_FLAG_BARCODE_SCANNER 0x07
66
Dave Sparksc62f9bd2009-06-26 13:33:32 -070067// msgType in notifyCallback and dataCallback functions
Dave Sparksd6289b12009-05-07 19:27:32 -070068enum {
Benny Wongda83f462009-08-12 12:01:27 -050069 CAMERA_MSG_ERROR = 0x001,
70 CAMERA_MSG_SHUTTER = 0x002,
71 CAMERA_MSG_FOCUS = 0x004,
72 CAMERA_MSG_ZOOM = 0x008,
73 CAMERA_MSG_PREVIEW_FRAME = 0x010,
74 CAMERA_MSG_VIDEO_FRAME = 0x020,
75 CAMERA_MSG_POSTVIEW_FRAME = 0x040,
76 CAMERA_MSG_RAW_IMAGE = 0x080,
77 CAMERA_MSG_COMPRESSED_IMAGE = 0x100,
78 CAMERA_MSG_ALL_MSGS = 0x1FF
Dave Sparksd6289b12009-05-07 19:27:32 -070079};
80
Wu-cheng Li36f68b82009-09-28 16:14:58 -070081// cmdType in sendCommand functions
82enum {
83 CAMERA_CMD_START_SMOOTH_ZOOM = 1,
84 CAMERA_CMD_STOP_SMOOTH_ZOOM = 2,
Chih-Chung Changd1d77062010-01-22 17:49:48 -080085 CAMERA_CMD_SET_DISPLAY_ORIENTATION = 3,
Wu-cheng Li36f68b82009-09-28 16:14:58 -070086};
87
James Donga1b653d2009-07-02 10:04:20 -070088// camera fatal errors
89enum {
90 CAMERA_ERROR_UKNOWN = 1,
91 CAMERA_ERROR_SERVER_DIED = 100
92};
93
The Android Open Source Project9066cfe2009-03-03 19:31:44 -080094class ICameraService;
95class ICamera;
96class Surface;
97class Mutex;
98class String8;
99
Dave Sparks5e271152009-06-23 17:30:11 -0700100// ref-counted object for callbacks
101class CameraListener: virtual public RefBase
102{
103public:
104 virtual void notify(int32_t msgType, int32_t ext1, int32_t ext2) = 0;
105 virtual void postData(int32_t msgType, const sp<IMemory>& dataPtr) = 0;
Dave Sparks59c1a932009-07-08 15:56:53 -0700106 virtual void postDataTimestamp(nsecs_t timestamp, int32_t msgType, const sp<IMemory>& dataPtr) = 0;
Dave Sparks5e271152009-06-23 17:30:11 -0700107};
108
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800109class Camera : public BnCameraClient, public IBinder::DeathRecipient
110{
111public:
112 // construct a camera client from an existing remote
James Dong2adc2db2009-04-23 14:07:23 -0700113 static sp<Camera> create(const sp<ICamera>& camera);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800114 static sp<Camera> connect();
115 ~Camera();
116 void init();
117
118 status_t reconnect();
119 void disconnect();
120 status_t lock();
121 status_t unlock();
122
123 status_t getStatus() { return mStatus; }
124
125 // pass the buffered ISurface to the camera service
126 status_t setPreviewDisplay(const sp<Surface>& surface);
127 status_t setPreviewDisplay(const sp<ISurface>& surface);
128
129 // start preview mode, must call setPreviewDisplay first
130 status_t startPreview();
131
132 // stop preview mode
133 void stopPreview();
134
135 // get preview state
136 bool previewEnabled();
137
138 // start recording mode, must call setPreviewDisplay first
139 status_t startRecording();
140
141 // stop recording mode
142 void stopRecording();
143
144 // get recording state
145 bool recordingEnabled();
146
147 // release a recording frame
148 void releaseRecordingFrame(const sp<IMemory>& mem);
149
150 // autoFocus - status returned from callback
151 status_t autoFocus();
152
Chih-Chung Chang244f8c22009-09-15 14:51:56 +0800153 // cancel auto focus
154 status_t cancelAutoFocus();
155
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800156 // take a picture - picture returned from callback
157 status_t takePicture();
158
159 // set preview/capture parameters - key/value pairs
160 status_t setParameters(const String8& params);
161
162 // get preview/capture parameters - key/value pairs
163 String8 getParameters() const;
164
Wu-cheng Li36f68b82009-09-28 16:14:58 -0700165 // send command to camera driver
166 status_t sendCommand(int32_t cmd, int32_t arg1, int32_t arg2);
167
Dave Sparks5e271152009-06-23 17:30:11 -0700168 void setListener(const sp<CameraListener>& listener);
169 void setPreviewCallbackFlags(int preview_callback_flag);
170
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800171 // ICameraClient interface
Dave Sparks2a04aef2009-05-07 12:25:25 -0700172 virtual void notifyCallback(int32_t msgType, int32_t ext, int32_t ext2);
Dave Sparksd6289b12009-05-07 19:27:32 -0700173 virtual void dataCallback(int32_t msgType, const sp<IMemory>& dataPtr);
Dave Sparks59c1a932009-07-08 15:56:53 -0700174 virtual void dataCallbackTimestamp(nsecs_t timestamp, int32_t msgType, const sp<IMemory>& dataPtr);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800175
176 sp<ICamera> remote();
177
178private:
179 Camera();
Dave Sparks6f0602e2009-06-24 10:42:53 -0700180 Camera(const Camera&);
181 Camera& operator=(const Camera);
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800182 virtual void binderDied(const wp<IBinder>& who);
183
184 class DeathNotifier: public IBinder::DeathRecipient
185 {
186 public:
187 DeathNotifier() {
188 }
189
190 virtual void binderDied(const wp<IBinder>& who);
191 };
192
193 static sp<DeathNotifier> mDeathNotifier;
194
195 // helper function to obtain camera service handle
196 static const sp<ICameraService>& getCameraService();
197
198 sp<ICamera> mCamera;
199 status_t mStatus;
200
Dave Sparks5e271152009-06-23 17:30:11 -0700201 sp<CameraListener> mListener;
202
The Android Open Source Project9066cfe2009-03-03 19:31:44 -0800203 friend class DeathNotifier;
204
205 static Mutex mLock;
206 static sp<ICameraService> mCameraService;
207
208};
209
210}; // namespace android
211
212#endif