blob: 124f07f9c415f9a915005bd0127ce1786610d67c [file] [log] [blame]
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -07001/*
2 * Copyright (C) 2008 The Android Open Source Project
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -08003 * Copyright (C) 2008 HTC Inc.
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -07004 *
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
21#include <ui/ICameraClient.h>
22
23namespace android {
24
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -080025/*
26 * A set of bit masks for specifying how the received frames from preview are
27 * handled before the frame callback call.
28 *
29 * The least significant 3 bits of an "int" value are used for this purpose:
30 *
31 * ..... 0 0 0
32 * ^ ^ ^
33 * | | |---------> determine whether the callback is enabled or not
34 * | |-----------> determine whether the callback is one-shot or not
35 * |-------------> determine whether the frame is copied out or not
36 *
37 * For instance,
38 * 1. 0x00 disables the callback. In this case, copy out and one shot bits
39 * are ignored.
40 * 2. 0x01 enables a callback without copying out the recievied frames. A
41 * typical use case is the Camcorder application to avoid making costly
42 * frame copies.
43 * 3. 0x05 is enabling a callback with frame copied out repeatedly. A typical
44 * use case is the Camera application.
45 * 4. 0x07 is enabling a callback with frame copied out only once. A typical use
46 * case is the Barcode scanner application.
47 */
48#define FRAME_CALLBACK_FLAG_ENABLE_MASK 0x01
49#define FRAME_CALLBACK_FLAG_ONE_SHOT_MASK 0x02
50#define FRAME_CALLBACK_FLAG_COPY_OUT_MASK 0x04
51
52// Typical use cases
53#define FRAME_CALLBACK_FLAG_NOOP 0x00
54#define FRAME_CALLBACK_FLAG_CAMCORDER 0x01
55#define FRAME_CALLBACK_FLAG_CAMERA 0x05
56#define FRAME_CALLBACK_FLAG_BARCODE_SCANNER 0x07
57
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -070058class ICameraService;
59class ICamera;
60class Surface;
61class Mutex;
62class String8;
63
64typedef void (*shutter_callback)(void *cookie);
65typedef void (*frame_callback)(const sp<IMemory>& mem, void *cookie);
66typedef void (*autofocus_callback)(bool focused, void *cookie);
67typedef void (*error_callback)(status_t err, void *cookie);
68
69class Camera : public BnCameraClient, public IBinder::DeathRecipient
70{
71public:
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -080072 // construct a camera client from an existing remote
73 Camera(const sp<ICamera>& camera);
74
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -070075 static sp<Camera> connect();
76 ~Camera();
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -080077 void init();
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -070078
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -080079 status_t reconnect();
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -070080 void disconnect();
81
82 status_t getStatus() { return mStatus; }
83
84 // pass the buffered ISurface to the camera service
85 status_t setPreviewDisplay(const sp<Surface>& surface);
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -080086 status_t setPreviewDisplay(const sp<ISurface>& surface);
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -070087
88 // start preview mode, must call setPreviewDisplay first
89 status_t startPreview();
90
91 // stop preview mode
92 void stopPreview();
93
94 // autoFocus - status returned from callback
95 status_t autoFocus();
96
97 // take a picture - picture returned from callback
98 status_t takePicture();
99
100 // set preview/capture parameters - key/value pairs
101 status_t setParameters(const String8& params);
102
103 // get preview/capture parameters - key/value pairs
104 String8 getParameters() const;
105
106 void setShutterCallback(shutter_callback cb, void *cookie);
107 void setRawCallback(frame_callback cb, void *cookie);
108 void setJpegCallback(frame_callback cb, void *cookie);
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800109
110 void setFrameCallback(frame_callback cb,
111 void *cookie,
112 int frame_callback_flag = FRAME_CALLBACK_FLAG_NOOP);
113
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700114 void setErrorCallback(error_callback cb, void *cookie);
115 void setAutoFocusCallback(autofocus_callback cb, void *cookie);
116 // ICameraClient interface
117 virtual void shutterCallback();
118 virtual void rawCallback(const sp<IMemory>& picture);
119 virtual void jpegCallback(const sp<IMemory>& picture);
120 virtual void frameCallback(const sp<IMemory>& frame);
121 virtual void errorCallback(status_t error);
122 virtual void autoFocusCallback(bool focused);
123
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800124 sp<ICamera> remote();
125
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700126private:
127 Camera();
128 virtual void binderDied(const wp<IBinder>& who);
129
130 class DeathNotifier: public IBinder::DeathRecipient
131 {
132 public:
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800133 DeathNotifier() {
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700134 }
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800135
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700136 virtual void binderDied(const wp<IBinder>& who);
137 };
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800138
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700139 static sp<DeathNotifier> mDeathNotifier;
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800140
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700141 // helper function to obtain camera service handle
142 static const sp<ICameraService>& getCameraService();
143
144 sp<ICamera> mCamera;
145 status_t mStatus;
146
147 shutter_callback mShutterCallback;
148 void *mShutterCallbackCookie;
149 frame_callback mRawCallback;
150 void *mRawCallbackCookie;
151 frame_callback mJpegCallback;
152 void *mJpegCallbackCookie;
153 frame_callback mFrameCallback;
154 void *mFrameCallbackCookie;
155 error_callback mErrorCallback;
156 void *mErrorCallbackCookie;
157 autofocus_callback mAutoFocusCallback;
158 void *mAutoFocusCallbackCookie;
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800159
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700160 friend class DeathNotifier;
161
162 static Mutex mLock;
163 static sp<ICameraService> mCameraService;
The Android Open Source Projecte09fd9e2008-12-17 18:05:43 -0800164
The Android Open Source Project7c1b96a2008-10-21 07:00:00 -0700165};
166
167}; // namespace android
168
169#endif
170