Code drop from //branches/cupcake/...@124589
This commit is contained in:
268
pdk/docs/_audio_hardware_interface_8h-source.html
Executable file
268
pdk/docs/_audio_hardware_interface_8h-source.html
Executable file
@@ -0,0 +1,268 @@
|
||||
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
|
||||
<html xmlns="http://www.w3.org/1999/xhtml">
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1" />
|
||||
<title>Doxygen-Generated Content</title>
|
||||
<link href="doxygen.css" rel="stylesheet" type="text/css" />
|
||||
<style type="text/css">
|
||||
<!--
|
||||
.navigation {
|
||||
display: none;
|
||||
}
|
||||
-->
|
||||
</style>
|
||||
</head>
|
||||
<body>
|
||||
<!-- Generated by Doxygen 1.5.6 -->
|
||||
<div class="navigation" id="top">
|
||||
<div class="tabs">
|
||||
<ul>
|
||||
<li><a href="index.html"><span>Main Page</span></a></li>
|
||||
<li><a href="namespaces.html"><span>Namespaces</span></a></li>
|
||||
<li><a href="annotated.html"><span>Data Structures</span></a></li>
|
||||
<li class="current"><a href="files.html"><span>Files</span></a></li>
|
||||
</ul>
|
||||
</div>
|
||||
</div>
|
||||
<h1>AudioHardwareInterface.h</h1><a href="_audio_hardware_interface_8h.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
|
||||
<a name="l00002"></a>00002 <span class="comment"> * Copyright (C) 2007 The Android Open Source Project</span>
|
||||
<a name="l00003"></a>00003 <span class="comment"> *</span>
|
||||
<a name="l00004"></a>00004 <span class="comment"> * Licensed under the Apache License, Version 2.0 (the "License");</span>
|
||||
<a name="l00005"></a>00005 <span class="comment"> * you may not use this file except in compliance with the License.</span>
|
||||
<a name="l00006"></a>00006 <span class="comment"> * You may obtain a copy of the License at</span>
|
||||
<a name="l00007"></a>00007 <span class="comment"> *</span>
|
||||
<a name="l00008"></a>00008 <span class="comment"> * http://www.apache.org/licenses/LICENSE-2.0</span>
|
||||
<a name="l00009"></a>00009 <span class="comment"> *</span>
|
||||
<a name="l00010"></a>00010 <span class="comment"> * Unless required by applicable law or agreed to in writing, software</span>
|
||||
<a name="l00011"></a>00011 <span class="comment"> * distributed under the License is distributed on an "AS IS" BASIS,</span>
|
||||
<a name="l00012"></a>00012 <span class="comment"> * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span>
|
||||
<a name="l00013"></a>00013 <span class="comment"> * See the License for the specific language governing permissions and</span>
|
||||
<a name="l00014"></a>00014 <span class="comment"> * limitations under the License.</span>
|
||||
<a name="l00015"></a>00015 <span class="comment"> */</span>
|
||||
<a name="l00016"></a>00016
|
||||
<a name="l00017"></a>00017 <span class="preprocessor">#ifndef ANDROID_AUDIO_HARDWARE_INTERFACE_H</span>
|
||||
<a name="l00018"></a>00018 <span class="preprocessor"></span><span class="preprocessor">#define ANDROID_AUDIO_HARDWARE_INTERFACE_H</span>
|
||||
<a name="l00019"></a>00019 <span class="preprocessor"></span>
|
||||
<a name="l00020"></a>00020 <span class="preprocessor">#include <stdint.h></span>
|
||||
<a name="l00021"></a>00021 <span class="preprocessor">#include <sys/types.h></span>
|
||||
<a name="l00022"></a>00022
|
||||
<a name="l00023"></a>00023 <span class="preprocessor">#include <utils/Errors.h></span>
|
||||
<a name="l00024"></a>00024 <span class="preprocessor">#include <utils/Vector.h></span>
|
||||
<a name="l00025"></a>00025 <span class="preprocessor">#include <utils/String16.h></span>
|
||||
<a name="l00026"></a>00026
|
||||
<a name="l00027"></a>00027 <span class="preprocessor">#include <media/IAudioFlinger.h></span>
|
||||
<a name="l00028"></a>00028 <span class="preprocessor">#include "media/AudioSystem.h"</span>
|
||||
<a name="l00029"></a>00029
|
||||
<a name="l00030"></a>00030
|
||||
<a name="l00031"></a><a class="code" href="namespaceandroid.html">00031</a> <span class="keyword">namespace </span>android {
|
||||
<a name="l00032"></a>00032
|
||||
<a name="l00033"></a>00033 <span class="comment">// ----------------------------------------------------------------------------</span>
|
||||
<a name="l00034"></a>00034 <span class="comment"></span>
|
||||
<a name="l00035"></a>00035 <span class="comment">/**</span>
|
||||
<a name="l00036"></a>00036 <span class="comment"> * AudioStreamOut is the abstraction interface for the audio output hardware.</span>
|
||||
<a name="l00037"></a>00037 <span class="comment"> *</span>
|
||||
<a name="l00038"></a>00038 <span class="comment"> * It provides information about various properties of the audio output hardware driver.</span>
|
||||
<a name="l00039"></a>00039 <span class="comment"> */</span>
|
||||
<a name="l00040"></a><a class="code" href="classandroid_1_1_audio_stream_out.html">00040</a> <span class="keyword">class </span><a class="code" href="classandroid_1_1_audio_stream_out.html" title="AudioStreamOut is the abstraction interface for the audio output hardware.">AudioStreamOut</a> {
|
||||
<a name="l00041"></a>00041 <span class="keyword">public</span>:
|
||||
<a name="l00042"></a>00042 <span class="keyword">virtual</span> <a class="code" href="classandroid_1_1_audio_stream_out.html#09074dbae95b82d4f83c513035a0034f">~AudioStreamOut</a>() = 0;
|
||||
<a name="l00043"></a>00043 <span class="comment"></span>
|
||||
<a name="l00044"></a>00044 <span class="comment"> /** return audio sampling rate in hz - eg. 44100 */</span>
|
||||
<a name="l00045"></a>00045 <span class="keyword">virtual</span> uint32_t <a class="code" href="classandroid_1_1_audio_stream_out.html#6bb028e125d13289f26d3d74f851c921" title="return audio sampling rate in hz - eg.">sampleRate</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00046"></a>00046 <span class="comment"></span>
|
||||
<a name="l00047"></a>00047 <span class="comment"> /** returns size of output buffer - eg. 4800 */</span>
|
||||
<a name="l00048"></a>00048 <span class="keyword">virtual</span> <span class="keywordtype">size_t</span> <a class="code" href="classandroid_1_1_audio_stream_out.html#7b3c5f2ce79b9b6f167408f63d19af0a" title="returns size of output buffer - eg.">bufferSize</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00049"></a>00049 <span class="comment"></span>
|
||||
<a name="l00050"></a>00050 <span class="comment"> /**</span>
|
||||
<a name="l00051"></a>00051 <span class="comment"> * return number of output audio channels.</span>
|
||||
<a name="l00052"></a>00052 <span class="comment"> * Acceptable values are 1 (mono) or 2 (stereo)</span>
|
||||
<a name="l00053"></a>00053 <span class="comment"> */</span>
|
||||
<a name="l00054"></a>00054 <span class="keyword">virtual</span> <span class="keywordtype">int</span> <a class="code" href="classandroid_1_1_audio_stream_out.html#4e880a5379c168e8f68c26827e41275b" title="return number of output audio channels.">channelCount</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00055"></a>00055 <span class="comment"></span>
|
||||
<a name="l00056"></a>00056 <span class="comment"> /**</span>
|
||||
<a name="l00057"></a>00057 <span class="comment"> * return audio format in 8bit or 16bit PCM format -</span>
|
||||
<a name="l00058"></a>00058 <span class="comment"> * eg. AudioSystem:PCM_16_BIT</span>
|
||||
<a name="l00059"></a>00059 <span class="comment"> */</span>
|
||||
<a name="l00060"></a>00060 <span class="keyword">virtual</span> <span class="keywordtype">int</span> <a class="code" href="classandroid_1_1_audio_stream_out.html#eb2b430bbff4eebd8fb8590507b1dce1" title="return audio format in 8bit or 16bit PCM format - eg.">format</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00061"></a>00061 <span class="comment"></span>
|
||||
<a name="l00062"></a>00062 <span class="comment"> /**</span>
|
||||
<a name="l00063"></a>00063 <span class="comment"> * return the frame size (number of bytes per sample).</span>
|
||||
<a name="l00064"></a>00064 <span class="comment"> */</span>
|
||||
<a name="l00065"></a><a class="code" href="classandroid_1_1_audio_stream_out.html#66b7c4bb510db4060adfd03a376897d8">00065</a> uint32_t <a class="code" href="classandroid_1_1_audio_stream_out.html#66b7c4bb510db4060adfd03a376897d8" title="return the frame size (number of bytes per sample).">frameSize</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classandroid_1_1_audio_stream_out.html#4e880a5379c168e8f68c26827e41275b" title="return number of output audio channels.">channelCount</a>()*((<a class="code" href="classandroid_1_1_audio_stream_out.html#eb2b430bbff4eebd8fb8590507b1dce1" title="return audio format in 8bit or 16bit PCM format - eg.">format</a>()==AudioSystem::PCM_16_BIT)?<span class="keyword">sizeof</span>(int16_t):<span class="keyword">sizeof</span>(int8_t)); }
|
||||
<a name="l00066"></a>00066 <span class="comment"></span>
|
||||
<a name="l00067"></a>00067 <span class="comment"> /**</span>
|
||||
<a name="l00068"></a>00068 <span class="comment"> * return the audio hardware driver latency in milli seconds.</span>
|
||||
<a name="l00069"></a>00069 <span class="comment"> */</span>
|
||||
<a name="l00070"></a>00070 <span class="keyword">virtual</span> uint32_t <a class="code" href="classandroid_1_1_audio_stream_out.html#c698a3d95cf0829dcfe283cd5ea437cb" title="return the audio hardware driver latency in milli seconds.">latency</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00071"></a>00071 <span class="comment"></span>
|
||||
<a name="l00072"></a>00072 <span class="comment"> /**</span>
|
||||
<a name="l00073"></a>00073 <span class="comment"> * Use this method in situations where audio mixing is done in the</span>
|
||||
<a name="l00074"></a>00074 <span class="comment"> * hardware. This method serves as a direct interface with hardware,</span>
|
||||
<a name="l00075"></a>00075 <span class="comment"> * allowing you to directly set the volume as apposed to via the framework.</span>
|
||||
<a name="l00076"></a>00076 <span class="comment"> * This method might produce multiple PCM outputs or hardware accelerated</span>
|
||||
<a name="l00077"></a>00077 <span class="comment"> * codecs, such as MP3 or AAC.</span>
|
||||
<a name="l00078"></a>00078 <span class="comment"> */</span>
|
||||
<a name="l00079"></a>00079 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_stream_out.html#e6d301925d193c25561b42239c7f44b6" title="Use this method in situations where audio mixing is done in the hardware.">setVolume</a>(<span class="keywordtype">float</span> volume) = 0;
|
||||
<a name="l00080"></a>00080 <span class="comment"></span>
|
||||
<a name="l00081"></a>00081 <span class="comment"> /** write audio buffer to driver. Returns number of bytes written */</span>
|
||||
<a name="l00082"></a>00082 <span class="keyword">virtual</span> ssize_t <a class="code" href="classandroid_1_1_audio_stream_out.html#cba177e4a4a35a87ab9f8aa2a9c0e78e" title="write audio buffer to driver.">write</a>(<span class="keyword">const</span> <span class="keywordtype">void</span>* buffer, <span class="keywordtype">size_t</span> bytes) = 0;
|
||||
<a name="l00083"></a>00083 <span class="comment"></span>
|
||||
<a name="l00084"></a>00084 <span class="comment"> /** dump the state of the audio output device */</span>
|
||||
<a name="l00085"></a>00085 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_stream_out.html#97e3cc4610ba40d6c37b3d376a032b98" title="dump the state of the audio output device">dump</a>(<span class="keywordtype">int</span> fd, <span class="keyword">const</span> Vector<String16>& args) = 0;
|
||||
<a name="l00086"></a>00086 };
|
||||
<a name="l00087"></a>00087 <span class="comment"></span>
|
||||
<a name="l00088"></a>00088 <span class="comment">/**</span>
|
||||
<a name="l00089"></a>00089 <span class="comment"> * AudioStreamIn is the abstraction interface for the audio input hardware.</span>
|
||||
<a name="l00090"></a>00090 <span class="comment"> *</span>
|
||||
<a name="l00091"></a>00091 <span class="comment"> * It defines the various properties of the audio hardware input driver.</span>
|
||||
<a name="l00092"></a>00092 <span class="comment"> */</span>
|
||||
<a name="l00093"></a><a class="code" href="classandroid_1_1_audio_stream_in.html">00093</a> <span class="keyword">class </span><a class="code" href="classandroid_1_1_audio_stream_in.html" title="AudioStreamIn is the abstraction interface for the audio input hardware.">AudioStreamIn</a> {
|
||||
<a name="l00094"></a>00094 <span class="keyword">public</span>:
|
||||
<a name="l00095"></a>00095 <span class="keyword">virtual</span> <a class="code" href="classandroid_1_1_audio_stream_in.html#72067577568bbdd0163c1369fe80f101">~AudioStreamIn</a>() = 0;
|
||||
<a name="l00096"></a>00096 <span class="comment"></span>
|
||||
<a name="l00097"></a>00097 <span class="comment"> /** return the input buffer size allowed by audio driver */</span>
|
||||
<a name="l00098"></a>00098 <span class="keyword">virtual</span> <span class="keywordtype">size_t</span> <a class="code" href="classandroid_1_1_audio_stream_in.html#a458f9cde3edde82f256af7eaa7b2ddf" title="return the input buffer size allowed by audio driver">bufferSize</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00099"></a>00099 <span class="comment"></span>
|
||||
<a name="l00100"></a>00100 <span class="comment"> /** return the number of audio input channels */</span>
|
||||
<a name="l00101"></a>00101 <span class="keyword">virtual</span> <span class="keywordtype">int</span> <a class="code" href="classandroid_1_1_audio_stream_in.html#04f84006dd5f2e0a5e512897a039f851" title="return the number of audio input channels">channelCount</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00102"></a>00102 <span class="comment"></span>
|
||||
<a name="l00103"></a>00103 <span class="comment"> /**</span>
|
||||
<a name="l00104"></a>00104 <span class="comment"> * return audio format in 8bit or 16bit PCM format -</span>
|
||||
<a name="l00105"></a>00105 <span class="comment"> * eg. AudioSystem:PCM_16_BIT</span>
|
||||
<a name="l00106"></a>00106 <span class="comment"> */</span>
|
||||
<a name="l00107"></a>00107 <span class="keyword">virtual</span> <span class="keywordtype">int</span> <a class="code" href="classandroid_1_1_audio_stream_in.html#4ade98c5243b9ed5f3a71a8f36e74b36" title="return audio format in 8bit or 16bit PCM format - eg.">format</a>() <span class="keyword">const</span> = 0;
|
||||
<a name="l00108"></a>00108 <span class="comment"></span>
|
||||
<a name="l00109"></a>00109 <span class="comment"> /**</span>
|
||||
<a name="l00110"></a>00110 <span class="comment"> * return the frame size (number of bytes per sample).</span>
|
||||
<a name="l00111"></a>00111 <span class="comment"> */</span>
|
||||
<a name="l00112"></a><a class="code" href="classandroid_1_1_audio_stream_in.html#43d2c6b97806c005f0717a7bb6f7595c">00112</a> uint32_t <a class="code" href="classandroid_1_1_audio_stream_in.html#43d2c6b97806c005f0717a7bb6f7595c" title="return the frame size (number of bytes per sample).">frameSize</a>()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> <a class="code" href="classandroid_1_1_audio_stream_in.html#04f84006dd5f2e0a5e512897a039f851" title="return the number of audio input channels">channelCount</a>()*((<a class="code" href="classandroid_1_1_audio_stream_in.html#4ade98c5243b9ed5f3a71a8f36e74b36" title="return audio format in 8bit or 16bit PCM format - eg.">format</a>()==AudioSystem::PCM_16_BIT)?<span class="keyword">sizeof</span>(int16_t):<span class="keyword">sizeof</span>(int8_t)); }
|
||||
<a name="l00113"></a>00113 <span class="comment"></span>
|
||||
<a name="l00114"></a>00114 <span class="comment"> /** set the input gain for the audio driver. This method is for</span>
|
||||
<a name="l00115"></a>00115 <span class="comment"> * for future use */</span>
|
||||
<a name="l00116"></a>00116 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_stream_in.html#339822afb3f2f2ac1b4c775d31d12440" title="set the input gain for the audio driver.">setGain</a>(<span class="keywordtype">float</span> gain) = 0;
|
||||
<a name="l00117"></a>00117 <span class="comment"></span>
|
||||
<a name="l00118"></a>00118 <span class="comment"> /** read audio buffer in from audio driver */</span>
|
||||
<a name="l00119"></a>00119 <span class="keyword">virtual</span> ssize_t <a class="code" href="classandroid_1_1_audio_stream_in.html#7c313cbfbb47dafd90f3225bcd26e592" title="read audio buffer in from audio driver">read</a>(<span class="keywordtype">void</span>* buffer, ssize_t bytes) = 0;
|
||||
<a name="l00120"></a>00120 <span class="comment"></span>
|
||||
<a name="l00121"></a>00121 <span class="comment"> /** dump the state of the audio input device */</span>
|
||||
<a name="l00122"></a>00122 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_stream_in.html#18c3760208bfb99498715a0d4977f675" title="dump the state of the audio input device">dump</a>(<span class="keywordtype">int</span> fd, <span class="keyword">const</span> Vector<String16>& args) = 0;
|
||||
<a name="l00123"></a>00123 <span class="comment"></span>
|
||||
<a name="l00124"></a>00124 <span class="comment"> /**</span>
|
||||
<a name="l00125"></a>00125 <span class="comment"> * Put the audio hardware input into standby mode. Returns</span>
|
||||
<a name="l00126"></a>00126 <span class="comment"> * status based on include/utils/Errors.h</span>
|
||||
<a name="l00127"></a>00127 <span class="comment"> */</span>
|
||||
<a name="l00128"></a>00128 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_stream_in.html#93fab46e8afdbaedd4d20cc6ee2b7c41" title="Put the audio hardware input into standby mode.">standby</a>() = 0;
|
||||
<a name="l00129"></a>00129
|
||||
<a name="l00130"></a>00130 };
|
||||
<a name="l00131"></a>00131 <span class="comment"></span>
|
||||
<a name="l00132"></a>00132 <span class="comment">/**</span>
|
||||
<a name="l00133"></a>00133 <span class="comment"> * AudioHardwareInterface.h defines the interface to the audio hardware abstraction layer.</span>
|
||||
<a name="l00134"></a>00134 <span class="comment"> *</span>
|
||||
<a name="l00135"></a>00135 <span class="comment"> * The interface supports setting and getting parameters, selecting audio routing</span>
|
||||
<a name="l00136"></a>00136 <span class="comment"> * paths, and defining input and output streams.</span>
|
||||
<a name="l00137"></a>00137 <span class="comment"> *</span>
|
||||
<a name="l00138"></a>00138 <span class="comment"> * AudioFlinger initializes the audio hardware and immediately opens an output stream.</span>
|
||||
<a name="l00139"></a>00139 <span class="comment"> * You can set Audio routing to output to handset, speaker, Bluetooth, or a headset.</span>
|
||||
<a name="l00140"></a>00140 <span class="comment"> *</span>
|
||||
<a name="l00141"></a>00141 <span class="comment"> * The audio input stream is initialized when AudioFlinger is called to carry out</span>
|
||||
<a name="l00142"></a>00142 <span class="comment"> * a record operation.</span>
|
||||
<a name="l00143"></a>00143 <span class="comment"> */</span>
|
||||
<a name="l00144"></a><a class="code" href="classandroid_1_1_audio_hardware_interface.html">00144</a> <span class="keyword">class </span><a class="code" href="classandroid_1_1_audio_hardware_interface.html" title="AudioHardwareInterface.h defines the interface to the audio hardware abstraction...">AudioHardwareInterface</a>
|
||||
<a name="l00145"></a>00145 {
|
||||
<a name="l00146"></a>00146 <span class="keyword">public</span>:<span class="comment"></span>
|
||||
<a name="l00147"></a>00147 <span class="comment"> /**</span>
|
||||
<a name="l00148"></a>00148 <span class="comment"> * check to see if the audio hardware interface has been initialized.</span>
|
||||
<a name="l00149"></a>00149 <span class="comment"> * return status based on values defined in include/utils/Errors.h</span>
|
||||
<a name="l00150"></a>00150 <span class="comment"> */</span>
|
||||
<a name="l00151"></a>00151 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#b7e19e09fa6cbc07c127122fa9866c50" title="check to see if the audio hardware interface has been initialized.">initCheck</a>() = 0;
|
||||
<a name="l00152"></a>00152 <span class="comment"></span>
|
||||
<a name="l00153"></a>00153 <span class="comment"> /**</span>
|
||||
<a name="l00154"></a>00154 <span class="comment"> * put the audio hardware into standby mode to conserve power. Returns</span>
|
||||
<a name="l00155"></a>00155 <span class="comment"> * status based on include/utils/Errors.h</span>
|
||||
<a name="l00156"></a>00156 <span class="comment"> */</span>
|
||||
<a name="l00157"></a>00157 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#61121d365bb4d182bdec2c1b12fb1178" title="put the audio hardware into standby mode to conserve power.">standby</a>() = 0;
|
||||
<a name="l00158"></a>00158 <span class="comment"></span>
|
||||
<a name="l00159"></a>00159 <span class="comment"> /** set the audio volume of a voice call. Range is between 0.0 and 1.0 */</span>
|
||||
<a name="l00160"></a>00160 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#7b7418072df1eeaacc89cd0c725755f6" title="set the audio volume of a voice call.">setVoiceVolume</a>(<span class="keywordtype">float</span> volume) = 0;
|
||||
<a name="l00161"></a>00161 <span class="comment"></span>
|
||||
<a name="l00162"></a>00162 <span class="comment"> /**</span>
|
||||
<a name="l00163"></a>00163 <span class="comment"> * set the audio volume for all audio activities other than voice call.</span>
|
||||
<a name="l00164"></a>00164 <span class="comment"> * Range between 0.0 and 1.0. If any value other than NO_ERROR is returned,</span>
|
||||
<a name="l00165"></a>00165 <span class="comment"> * the software mixer will emulate this capability.</span>
|
||||
<a name="l00166"></a>00166 <span class="comment"> */</span>
|
||||
<a name="l00167"></a>00167 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#925092e556eb89f304bcebb09f90c9a3" title="set the audio volume for all audio activities other than voice call.">setMasterVolume</a>(<span class="keywordtype">float</span> volume) = 0;
|
||||
<a name="l00168"></a>00168 <span class="comment"></span>
|
||||
<a name="l00169"></a>00169 <span class="comment"> /**</span>
|
||||
<a name="l00170"></a>00170 <span class="comment"> * Audio routing methods. Routes defined in include/hardware/AudioSystem.h.</span>
|
||||
<a name="l00171"></a>00171 <span class="comment"> * Audio routes can be (ROUTE_EARPIECE | ROUTE_SPEAKER | ROUTE_BLUETOOTH</span>
|
||||
<a name="l00172"></a>00172 <span class="comment"> * | ROUTE_HEADSET)</span>
|
||||
<a name="l00173"></a>00173 <span class="comment"> *</span>
|
||||
<a name="l00174"></a>00174 <span class="comment"> * setRouting sets the routes for a mode. This is called at startup. It is</span>
|
||||
<a name="l00175"></a>00175 <span class="comment"> * also called when a new device is connected, such as a wired headset is</span>
|
||||
<a name="l00176"></a>00176 <span class="comment"> * plugged in or a Bluetooth headset is paired.</span>
|
||||
<a name="l00177"></a>00177 <span class="comment"> */</span>
|
||||
<a name="l00178"></a>00178 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#39b2690e19219425b8cff093ef83bfb1" title="Audio routing methods.">setRouting</a>(<span class="keywordtype">int</span> mode, uint32_t routes) = 0;
|
||||
<a name="l00179"></a>00179
|
||||
<a name="l00180"></a>00180 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#1886de8fff2342ae628dbbbc0c45ba83">getRouting</a>(<span class="keywordtype">int</span> mode, uint32_t* routes) = 0;
|
||||
<a name="l00181"></a>00181 <span class="comment"></span>
|
||||
<a name="l00182"></a>00182 <span class="comment"> /**</span>
|
||||
<a name="l00183"></a>00183 <span class="comment"> * setMode is called when the audio mode changes. NORMAL mode is for</span>
|
||||
<a name="l00184"></a>00184 <span class="comment"> * standard audio playback, RINGTONE when a ringtone is playing, and IN_CALL</span>
|
||||
<a name="l00185"></a>00185 <span class="comment"> * when a call is in progress.</span>
|
||||
<a name="l00186"></a>00186 <span class="comment"> */</span>
|
||||
<a name="l00187"></a>00187 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#aaf2a429c240f00b21836794849b430f" title="setMode is called when the audio mode changes.">setMode</a>(<span class="keywordtype">int</span> mode) = 0;
|
||||
<a name="l00188"></a>00188 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#8466c76328a51b8a83da103032abba55">getMode</a>(<span class="keywordtype">int</span>* mode) = 0;
|
||||
<a name="l00189"></a>00189
|
||||
<a name="l00190"></a>00190 <span class="comment">// mic mute</span>
|
||||
<a name="l00191"></a>00191 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#be35b7cb738531939a3ac9abc5514621">setMicMute</a>(<span class="keywordtype">bool</span> state) = 0;
|
||||
<a name="l00192"></a>00192 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#15d3c33d7e3f965dc2588c537f05a133">getMicMute</a>(<span class="keywordtype">bool</span>* state) = 0;
|
||||
<a name="l00193"></a>00193
|
||||
<a name="l00194"></a>00194 <span class="comment">// Temporary interface, do not use</span>
|
||||
<a name="l00195"></a>00195 <span class="comment">// TODO: Replace with a more generic key:value get/set mechanism</span>
|
||||
<a name="l00196"></a>00196 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#a1b477901df48b3a27103a77e6bb39c8">setParameter</a>(<span class="keyword">const</span> <span class="keywordtype">char</span>* key, <span class="keyword">const</span> <span class="keywordtype">char</span>* value) = 0;
|
||||
<a name="l00197"></a>00197
|
||||
<a name="l00198"></a>00198 <span class="comment">// Returns audio input buffer size according to parameters passed or 0 if one of the</span>
|
||||
<a name="l00199"></a>00199 <span class="comment">// parameters is not supported</span>
|
||||
<a name="l00200"></a>00200 <span class="keyword">virtual</span> <span class="keywordtype">size_t</span> <a class="code" href="classandroid_1_1_audio_hardware_interface.html#19f68d873b2a6e4c00c017c580170395">getInputBufferSize</a>(uint32_t sampleRate, <span class="keywordtype">int</span> format, <span class="keywordtype">int</span> channelCount) = 0;
|
||||
<a name="l00201"></a>00201 <span class="comment"></span>
|
||||
<a name="l00202"></a>00202 <span class="comment"> /** This method creates and opens the audio hardware output stream */</span>
|
||||
<a name="l00203"></a>00203 <span class="keyword">virtual</span> <a class="code" href="classandroid_1_1_audio_stream_out.html" title="AudioStreamOut is the abstraction interface for the audio output hardware.">AudioStreamOut</a>* <a class="code" href="classandroid_1_1_audio_hardware_interface.html#eda0986e145c8dd68d21cb79051f94f9" title="This method creates and opens the audio hardware output stream.">openOutputStream</a>(
|
||||
<a name="l00204"></a>00204 <span class="keywordtype">int</span> format=0,
|
||||
<a name="l00205"></a>00205 <span class="keywordtype">int</span> channelCount=0,
|
||||
<a name="l00206"></a>00206 uint32_t sampleRate=0,
|
||||
<a name="l00207"></a>00207 status_t *status=0) = 0;
|
||||
<a name="l00208"></a>00208 <span class="comment"></span>
|
||||
<a name="l00209"></a>00209 <span class="comment"> /** This method creates and opens the audio hardware input stream */</span>
|
||||
<a name="l00210"></a>00210 <span class="keyword">virtual</span> <a class="code" href="classandroid_1_1_audio_stream_in.html" title="AudioStreamIn is the abstraction interface for the audio input hardware.">AudioStreamIn</a>* <a class="code" href="classandroid_1_1_audio_hardware_interface.html#efb777d192fcbcd65458fa4f2d976476" title="This method creates and opens the audio hardware input stream.">openInputStream</a>(
|
||||
<a name="l00211"></a>00211 <span class="keywordtype">int</span> format,
|
||||
<a name="l00212"></a>00212 <span class="keywordtype">int</span> channelCount,
|
||||
<a name="l00213"></a>00213 uint32_t sampleRate,
|
||||
<a name="l00214"></a>00214 status_t *status) = 0;
|
||||
<a name="l00215"></a>00215 <span class="comment"></span>
|
||||
<a name="l00216"></a>00216 <span class="comment"> /**This method dumps the state of the audio hardware */</span>
|
||||
<a name="l00217"></a>00217 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#05f035af60e67a22251175b44a089f69" title="This method dumps the state of the audio hardware.">dumpState</a>(<span class="keywordtype">int</span> fd, <span class="keyword">const</span> Vector<String16>& args) = 0;
|
||||
<a name="l00218"></a>00218
|
||||
<a name="l00219"></a>00219 <span class="keyword">static</span> <a class="code" href="classandroid_1_1_audio_hardware_interface.html" title="AudioHardwareInterface.h defines the interface to the audio hardware abstraction...">AudioHardwareInterface</a>* <a class="code" href="classandroid_1_1_audio_hardware_interface.html#aa5ae45e9ad969fefc494e103cf5068d">create</a>();
|
||||
<a name="l00220"></a>00220
|
||||
<a name="l00221"></a>00221 <span class="keyword">protected</span>:<span class="comment"></span>
|
||||
<a name="l00222"></a>00222 <span class="comment"> /**</span>
|
||||
<a name="l00223"></a>00223 <span class="comment"> * doRouting actually initiates the routing. A call to setRouting</span>
|
||||
<a name="l00224"></a>00224 <span class="comment"> * or setMode may result in a routing change. The generic logic calls</span>
|
||||
<a name="l00225"></a>00225 <span class="comment"> * doRouting when required. If the device has any special requirements these</span>
|
||||
<a name="l00226"></a>00226 <span class="comment"> * methods can be overriden.</span>
|
||||
<a name="l00227"></a>00227 <span class="comment"> */</span>
|
||||
<a name="l00228"></a>00228 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#d82c3e4827f275abf28eb872e8751e1f" title="doRouting actually initiates the routing.">doRouting</a>() = 0;
|
||||
<a name="l00229"></a>00229
|
||||
<a name="l00230"></a>00230 <span class="keyword">virtual</span> status_t <a class="code" href="classandroid_1_1_audio_hardware_interface.html#371f198a416cb726804e0f47e8763217">dump</a>(<span class="keywordtype">int</span> fd, <span class="keyword">const</span> Vector<String16>& args) = 0;
|
||||
<a name="l00231"></a>00231 };
|
||||
<a name="l00232"></a>00232
|
||||
<a name="l00233"></a>00233 <span class="comment">// ----------------------------------------------------------------------------</span>
|
||||
<a name="l00234"></a>00234
|
||||
<a name="l00235"></a>00235 <span class="keyword">extern</span> <span class="stringliteral">"C"</span> <a class="code" href="classandroid_1_1_audio_hardware_interface.html" title="AudioHardwareInterface.h defines the interface to the audio hardware abstraction...">AudioHardwareInterface</a>* <a class="code" href="namespaceandroid.html#dcc80314ddffcb0981a9e9c5468662f8">createAudioHardware</a>(<span class="keywordtype">void</span>);
|
||||
<a name="l00236"></a>00236
|
||||
<a name="l00237"></a>00237 }; <span class="comment">// namespace android</span>
|
||||
<a name="l00238"></a>00238
|
||||
<a name="l00239"></a>00239 <span class="preprocessor">#endif // ANDROID_AUDIO_HARDWARE_INTERFACE_H</span>
|
||||
</pre></div></div>
|
||||
</body>
|
||||
</html>
|
||||
Reference in New Issue
Block a user