00036 * AudioStreamOut is the abstraction interface for the audio output hardware.
00038 * It provides information about various properties of the audio output hardware driver.
00047 /** returns size of output buffer - eg. 4800 */
00051 * return number of output audio channels.
00058 * eg. AudioSystem:PCM_16_BIT
00063 * return the frame size (number of bytes per sample).
00068 * return the audio hardware driver latency in milli seconds.
00075 * allowing you to directly set the volume as apposed to via the framework.
00077 * codecs, such as MP3 or AAC.
& args) = 0;
00092 };
00093
00094 /**
00095 * AudioStreamIn is the abstraction interface for the audio input hardware.
00096 *
00097 * It defines the various properties of the audio hardware input driver.
00098 */
00099 class AudioStreamIn {
00100 public:
00101 virtual ~AudioStreamIn() = 0;
00102
00103 /** return the input buffer size allowed by audio driver */
00104 virtual size_t bufferSize() const = 0;
00105
00106 /** return the number of audio input channels */
00107 virtual int channelCount() const = 0;
00108
00109 /**
00110 * return audio format in 8bit or 16bit PCM format -
00111 * eg. AudioSystem:PCM_16_BIT
00112 */
00113 virtual int format() const = 0;
00114
00115 /**
00116 * return the frame size (number of bytes per sample).
00117 */
00118 uint32_t frameSize() const { return channelCount()*((format()==AudioSystem::PCM_16_BIT)?sizeof(int16_t):sizeof(int8_t)); }
00119
00120 /** set the input gain for the audio driver. This method is for
00121 * for future use */
00122 virtual status_t setGain(float gain) = 0;
00123
00124 /** read audio buffer in from audio driver */
00125 virtual ssize_t read(void* buffer, ssize_t bytes) = 0;
00126
00127 /** dump the state of the audio input device */
00128 virtual status_t dump(int fd, const Vector& args) = 0;
00129
00130 /**
00131 * Put the audio hardware input into standby mode. Returns
00132 * status based on include/utils/Errors.h
00133 */
00134 virtual status_t standby() = 0;
00135
00136 };
00137
00138 /**
00139 * AudioHardwareInterface.h defines the interface to the audio hardware abstraction layer.
00140 *
00141 * The interface supports setting and getting parameters, selecting audio routing
00142 * paths, and defining input and output streams.
00143 *
00144 * AudioFlinger initializes the audio hardware and immediately opens an output stream.
00145 * You can set Audio routing to output to handset, speaker, Bluetooth, or a headset.
00146 *
00147 * The audio input stream is initialized when AudioFlinger is called to carry out
00148 * a record operation.
00149 */
00150 class AudioHardwareInterface
00151 {
00152 public:
00153 virtual ~AudioHardwareInterface() {}
00154
00155 /**
00156 * check to see if the audio hardware interface has been initialized.
00157 * return status based on values defined in include/utils/Errors.h
00158 */
00159 virtual status_t initCheck() = 0;
00160
00161 /** set the audio volume of a voice call. Range is between 0.0 and 1.0 */
00162 virtual status_t setVoiceVolume(float volume) = 0;
00163
00164 /**
00165 * set the audio volume for all audio activities other than voice call.
00166 * Range between 0.0 and 1.0. If any value other than NO_ERROR is returned,
00167 * the software mixer will emulate this capability.
00168 */
00169 virtual status_t setMasterVolume(float volume) = 0;
00170
00171 /**
00172 * Audio routing methods. Routes defined in include/hardware_legacy/AudioSystem.h.
00173 * Audio routes can be (ROUTE_EARPIECE | ROUTE_SPEAKER | ROUTE_BLUETOOTH
00174 * | ROUTE_HEADSET)
00175 *
00176 * setRouting sets the routes for a mode. This is called at startup. It is
00177 * also called when a new device is connected, such as a wired headset is
00178 * plugged in or a Bluetooth headset is paired.
00179 */
00180 virtual status_t setRouting(int mode, uint32_t routes) = 0;
00181
00182 virtual status_t getRouting(int mode, uint32_t* routes) = 0;
00183
00184 /**
00185 * setMode is called when the audio mode changes. NORMAL mode is for
00186 * standard audio playback, RINGTONE when a ringtone is playing, and IN_CALL
00187 * when a call is in progress.
00188 */
00189 virtual status_t setMode(int mode) = 0;
00190 virtual status_t getMode(int* mode) = 0;
00191
00192 // mic mute
00193 virtual status_t setMicMute(bool state) = 0;
00194 virtual status_t getMicMute(bool* state) = 0;
00195
00196 // Temporary interface, do not use
00197 // TODO: Replace with a more generic key:value get/set mechanism
00198 virtual status_t setParameter(const char* key, const char* value) = 0;
00199
00200 // Returns audio input buffer size according to parameters passed or 0 if one of the
00201 // parameters is not supported
00202 virtual size_t getInputBufferSize(uint32_t sampleRate, int format, int channelCount) = 0;
00203
00204 /** This method creates and opens the audio hardware output stream */
00205 virtual AudioStreamOut* openOutputStream(
00206 int format=0,
00207 int channelCount=0,
00208 uint32_t sampleRate=0,
00209 status_t *status=0) = 0;
00210
00211 /** This method creates and opens the audio hardware input stream */
00212 virtual AudioStreamIn* openInputStream(
00213 int inputSource,
00214 int format,
00215 int channelCount,
00216 uint32_t sampleRate,
00217 status_t *status,
00218 AudioSystem::audio_in_acoustics acoustics) = 0;
00219
00220 /**This method dumps the state of the audio hardware */
00221 virtual status_t dumpState(int fd, const Vector& args) = 0;
00222
00223 static AudioHardwareInterface* create();
00224
00225 protected:
00226 /**
00227 * doRouting actually initiates the routing. A call to setRouting
00228 * or setMode may result in a routing change. The generic logic calls
00229 * doRouting when required. If the device has any special requirements these
00230 * methods can be overriden.
00231 */
00232 virtual status_t doRouting() = 0;
00233
00234 virtual status_t dump(int fd, const Vector& args) = 0;
00235 };
00236
00237 // ----------------------------------------------------------------------------
00238
00239 extern "C" AudioHardwareInterface* createAudioHardware(void);
00240
00241 }; // namespace android
00242
00243 #endif // ANDROID_AUDIO_HARDWARE_INTERFACE_H
Camera
In this document
Android's camera subsystem connects the camera application to the application framework and user space libraries, which in turn communicate with the camera hardware layer that operates the physical camera.
The diagram below illustrates the structure of the camera subsystem.
Building a Camera Library
To implement a camera driver, create a shared library that implements the interface defined in CameraHardwareInterface.h. You must name your shared library libcamera.so so that it will get loaded from /system/lib at runtime. Place libcamera sources and Android.mk in vendor/acme/chipset_or_board/libcamera/.
The following stub Android.mk file ensures that libcamera compiles and links to the appropriate libraries:
LOCAL_PATH := $(call my-dir)
include $(CLEAR_VARS)
LOCAL_MODULE := libcamera
LOCAL_SHARED_LIBRARIES := \
libutils \
librpc \
liblog
LOCAL_SRC_FILES += MyCameraHardware.cpp
LOCAL_CFLAGS +=
LOCAL_C_INCLUDES +=
LOCAL_STATIC_LIBRARIES += \
libcamera-common \
libclock-rpc \
libcommondefs-rpc
include $(BUILD_SHARED_LIBRARY)
Sequence Diagrams
Preview
The following diagram illustrates the sequence of function calls and actions necessary for your camera to preview.
Taking a Picture
The following diagram illustrates the sequence of function calls and actions necessary for your camera to take a picture.
CameraHardwareInterface.h File Reference
Go to the source code of this file.
|
|
Namespaces
|
namespace
|
android
|
Data Structures
|
class
|
android::CameraHardwareInterface
|
|
CameraHardwareInterface.h defines the interface to the camera hardware abstraction layer, used for setting and getting parameters, live previewing, and taking pictures. More...
|
Typedefs
|
typedef void(*
|
android::autofocus_callback )(bool focused, void *user)
|
|
Callback for autoFocus().
|
typedef void(*
|
android::jpeg_callback )(const sp< IMemory > &mem, void *user)
|
|
Callback for takePicture().
|
typedef void(*
|
android::preview_callback )(const sp< IMemory > &mem, void *user)
|
|
Callback for startPreview().
|
typedef void(*
|
android::raw_callback )(const sp< IMemory > &mem, void *user)
|
|
Callback for takePicture().
|
typedef void(*
|
android::recording_callback )(nsecs_t timestamp, const sp< IMemory > &mem, void *user)
|
|
Callback for startRecord().
|
typedef void(*
|
android::shutter_callback )(void *user)
|
|
Callback for takePicture().
|
Functions
|
sp< CameraHardwareInterface >
|
android::openCameraHardware ()
|
|
factory function to instantiate a camera hardware object
|
Power Management
Introduction
Wake Locks
Types of Wake Locks
Exploring a Wake Lock Example
PowerManager class
Registering Drivers with the PM Driver
Early Suspend
Introduction
Android supports its own Power Management (on top of the standard Linux Power Management) designed with the premise that the CPU shouldn't consume power if no applications or services require power. For more information regarding standard Linux power management, please see Linux Power Management Support at http://kernel.org.
Android requires that applications and services request CPU resources with "wake locks" through the Android application framework and native Linux libraries. If there are no active wake locks, Android will shut down the CPU.
The image below illustrates the Android power management architecture.
Solid elements represent Android blocks and dashed elements represent partner-specific blocks.