1 /* 2 * Copyright (C) 2008-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 ANDROID_AUDIOPARAMETER_H_ 18 #define ANDROID_AUDIOPARAMETER_H_ 19 20 #include <utils/Errors.h> 21 #include <utils/KeyedVector.h> 22 #include <utils/String8.h> 23 24 namespace android { 25 26 class AudioParameter { 27 28 public: AudioParameter()29 AudioParameter() {} 30 AudioParameter(const String8& keyValuePairs); 31 virtual ~AudioParameter(); 32 33 // reserved parameter keys for changing standard parameters with setParameters() function. 34 // Using these keys is mandatory for AudioFlinger to properly monitor audio output/input 35 // configuration changes and act accordingly. 36 // keyRouting: to change audio routing, value is an int in audio_devices_t 37 // keySamplingRate: to change sampling rate routing, value is an int 38 // keyFormat: to change audio format, value is an int in audio_format_t 39 // keyChannels: to change audio channel configuration, value is an int in audio_channels_t 40 // keyFrameCount: to change audio output frame count, value is an int 41 // keyInputSource: to change audio input source, value is an int in audio_source_t 42 // (defined in media/mediarecorder.h) 43 // keyScreenState: either "on" or "off" 44 // keyScreenRotation: one of: 0, 90, 180, 270 45 static const char * const keyRouting; 46 static const char * const keySamplingRate; 47 static const char * const keyFormat; 48 static const char * const keyChannels; 49 static const char * const keyFrameCount; 50 static const char * const keyInputSource; 51 static const char * const keyScreenState; 52 static const char * const keyScreenRotation; 53 54 // keyClosing: "true" on AudioFlinger Thread preExit. Used by A2DP HAL. 55 // keyExiting: "1" on AudioFlinger Thread preExit. Used by remote_submix and A2DP HAL. 56 static const char * const keyClosing; 57 static const char * const keyExiting; 58 59 // keyBtSco: Whether BT SCO is 'on' or 'off' 60 // keyBtScoHeadsetName: BT SCO headset name (for debugging) 61 // keyBtNrec: BT SCO Noise Reduction + Echo Cancellation parameters 62 // keyBtScoWb: BT SCO NR wideband mode 63 // keyHfp...: Parameters of the Hands-Free Profile 64 static const char * const keyBtSco; 65 static const char * const keyBtScoHeadsetName; 66 static const char * const keyBtNrec; 67 static const char * const keyBtScoWb; 68 static const char * const keyBtHfpEnable; 69 static const char * const keyBtHfpSamplingRate; 70 static const char * const keyBtHfpVolume; 71 72 static const char * const keyTtyMode; 73 static const char * const valueTtyModeOff; 74 static const char * const valueTtyModeFull; 75 static const char * const valueTtyModeHco; 76 static const char * const valueTtyModeVco; 77 78 static const char * const keyHacSetting; 79 static const char * const valueHacOff; 80 static const char * const valueHacOn; 81 82 // keyHwAvSync: get HW synchronization source identifier from a device 83 // keyMonoOutput: Enable mono audio playback 84 // keyStreamHwAvSync: set HW synchronization source identifier on a stream 85 static const char * const keyHwAvSync; 86 static const char * const keyMonoOutput; 87 static const char * const keyStreamHwAvSync; 88 89 // keys for presentation selection 90 // keyPresentationId: Audio presentation identifier 91 // keyProgramId: Audio presentation program identifier 92 static const char * const keyPresentationId; 93 static const char * const keyProgramId; 94 95 // keyAudioLanguagePreferred: Preferred audio language 96 static const char * const keyAudioLanguagePreferred; 97 98 // keyDeviceConnect / Disconnect: value is an int in audio_devices_t 99 static const char * const keyDeviceConnect; 100 static const char * const keyDeviceDisconnect; 101 // Need to be here because vendors still use them. 102 static const char * const keyStreamConnect; // Deprecated: DO NOT USE. 103 static const char * const keyStreamDisconnect; // Deprecated: DO NOT USE. 104 105 // For querying stream capabilities. All the returned values are lists. 106 // keyStreamSupportedFormats: audio_format_t 107 // keyStreamSupportedChannels: audio_channel_mask_t 108 // keyStreamSupportedSamplingRates: sampling rate values 109 static const char * const keyStreamSupportedFormats; 110 static const char * const keyStreamSupportedChannels; 111 static const char * const keyStreamSupportedSamplingRates; 112 113 static const char * const valueOn; 114 static const char * const valueOff; 115 static const char * const valueTrue; 116 static const char * const valueFalse; 117 118 static const char * const valueListSeparator; 119 120 // keyBtA2dpSuspended: 'true' or 'false' 121 // keyReconfigA2dp: Ask HwModule to reconfigure A2DP offloaded codec 122 // keyReconfigA2dpSupported: Query if HwModule supports A2DP offload codec config 123 // keyBtLeSuspended: 'true' or 'false' 124 // keyReconfigLe: Ask HwModule to reconfigure LE offloaded codec 125 // keyReconfigLeSupported: Query if HwModule supports LE offload codec config 126 static const char * const keyBtA2dpSuspended; 127 static const char * const keyReconfigA2dp; 128 static const char * const keyReconfigA2dpSupported; 129 static const char * const keyBtLeSuspended; 130 static const char * const keyReconfigLe; 131 static const char * const keyReconfigLeSupported; 132 133 // For querying device supported encapsulation capabilities. All returned values are integer, 134 // which are bit fields composed from using encapsulation capability values as position bits. 135 // Encapsulation capability values are defined in audio_encapsulation_mode_t and 136 // audio_encapsulation_metadata_type_t. For instance, if the supported encapsulation mode is 137 // AUDIO_ENCAPSULATION_MODE_ELEMENTARY_STREAM, the returned value is 138 // "supEncapsulationModes=1 << AUDIO_ENCAPSULATION_MODE_HANDLE". 139 // When querying device supported encapsulation capabilities, the key should use with device 140 // type and address so that it is able to identify the device. The device will be a key. The 141 // device type will be the value of key AUDIO_PARAMETER_STREAM_ROUTING. 142 // static const char * const keyDeviceSupportedEncapsulationModes; 143 // static const char * const keyDeviceSupportedEncapsulationMetadataTypes; 144 145 static const char * const keyAdditionalOutputDeviceDelay; 146 static const char * const keyMaxAdditionalOutputDeviceDelay; 147 148 static const char * const keyOffloadCodecAverageBitRate; 149 static const char * const keyOffloadCodecSampleRate; 150 static const char * const keyOffloadCodecChannels; 151 static const char * const keyOffloadCodecDelaySamples; 152 static const char * const keyOffloadCodecPaddingSamples; 153 toString()154 String8 toString() const { return toStringImpl(true); } keysToString()155 String8 keysToString() const { return toStringImpl(false); } 156 157 status_t add(const String8& key, const String8& value); 158 status_t addInt(const String8& key, const int value); 159 status_t addKey(const String8& key); 160 status_t addFloat(const String8& key, const float value); 161 162 status_t remove(const String8& key); 163 get(const String8 & key,int & value)164 status_t get(const String8& key, int& value) const { 165 return getInt(key, value); 166 } get(const String8 & key,float & value)167 status_t get(const String8& key, float& value) const { 168 return getFloat(key, value); 169 } 170 status_t get(const String8& key, String8& value) const; 171 status_t getInt(const String8& key, int& value) const; 172 status_t getFloat(const String8& key, float& value) const; 173 status_t getAt(size_t index, String8& key) const; 174 status_t getAt(size_t index, String8& key, String8& value) const; 175 size()176 size_t size() const { return mParameters.size(); } 177 178 bool containsKey(const String8& key) const; 179 private: 180 String8 mKeyValuePairs; 181 KeyedVector <String8, String8> mParameters; 182 183 String8 toStringImpl(bool useValues) const; 184 }; 185 186 }; // namespace android 187 188 #endif /*ANDROID_AUDIOPARAMETER_H_*/ 189