OLD | NEW |
| (Empty) |
1 /* | |
2 * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. | |
3 * | |
4 * Use of this source code is governed by a BSD-style license | |
5 * that can be found in the LICENSE file in the root of the source | |
6 * tree. An additional intellectual property rights grant can be found | |
7 * in the file PATENTS. All contributing project authors may | |
8 * be found in the AUTHORS file in the root of the source tree. | |
9 */ | |
10 | |
11 // This sub-API supports the following functionalities: | |
12 // | |
13 // - Speaker volume controls. | |
14 // - Microphone volume control. | |
15 // - Non-linear speech level control. | |
16 // - Mute functions. | |
17 // - Additional stereo scaling methods. | |
18 // | |
19 // Usage example, omitting error checking: | |
20 // | |
21 // using namespace webrtc; | |
22 // VoiceEngine* voe = VoiceEngine::Create(); | |
23 // VoEBase* base = VoEBase::GetInterface(voe); | |
24 // VoEVolumeControl* volume = VoEVolumeControl::GetInterface(voe); | |
25 // base->Init(); | |
26 // int ch = base->CreateChannel(); | |
27 // ... | |
28 // volume->SetInputMute(ch, true); | |
29 // ... | |
30 // base->DeleteChannel(ch); | |
31 // base->Terminate(); | |
32 // base->Release(); | |
33 // volume->Release(); | |
34 // VoiceEngine::Delete(voe); | |
35 // | |
36 #ifndef WEBRTC_VOICE_ENGINE_VOE_VOLUME_CONTROL_H | |
37 #define WEBRTC_VOICE_ENGINE_VOE_VOLUME_CONTROL_H | |
38 | |
39 #include "webrtc/common_types.h" | |
40 | |
41 namespace webrtc { | |
42 | |
43 class VoiceEngine; | |
44 | |
45 class WEBRTC_DLLEXPORT VoEVolumeControl { | |
46 public: | |
47 // Factory for the VoEVolumeControl sub-API. Increases an internal | |
48 // reference counter if successful. Returns NULL if the API is not | |
49 // supported or if construction fails. | |
50 static VoEVolumeControl* GetInterface(VoiceEngine* voiceEngine); | |
51 | |
52 // Releases the VoEVolumeControl sub-API and decreases an internal | |
53 // reference counter. Returns the new reference count. This value should | |
54 // be zero for all sub-API:s before the VoiceEngine object can be safely | |
55 // deleted. | |
56 virtual int Release() = 0; | |
57 | |
58 // Sets the speaker |volume| level. Valid range is [0,255]. | |
59 virtual int SetSpeakerVolume(unsigned int volume) = 0; | |
60 | |
61 // Gets the speaker |volume| level. | |
62 virtual int GetSpeakerVolume(unsigned int& volume) = 0; | |
63 | |
64 // Sets the microphone volume level. Valid range is [0,255]. | |
65 virtual int SetMicVolume(unsigned int volume) = 0; | |
66 | |
67 // Gets the microphone volume level. | |
68 virtual int GetMicVolume(unsigned int& volume) = 0; | |
69 | |
70 // Mutes the microphone input signal completely without affecting | |
71 // the audio device volume. | |
72 virtual int SetInputMute(int channel, bool enable) = 0; | |
73 | |
74 // Gets the current microphone input mute state. | |
75 virtual int GetInputMute(int channel, bool& enabled) = 0; | |
76 | |
77 // Gets the microphone speech |level|, mapped non-linearly to the range | |
78 // [0,9]. | |
79 virtual int GetSpeechInputLevel(unsigned int& level) = 0; | |
80 | |
81 // Gets the speaker speech |level|, mapped non-linearly to the range | |
82 // [0,9]. | |
83 virtual int GetSpeechOutputLevel(int channel, unsigned int& level) = 0; | |
84 | |
85 // Gets the microphone speech |level|, mapped linearly to the range | |
86 // [0,32768]. | |
87 virtual int GetSpeechInputLevelFullRange(unsigned int& level) = 0; | |
88 | |
89 // Gets the speaker speech |level|, mapped linearly to the range [0,32768]. | |
90 virtual int GetSpeechOutputLevelFullRange(int channel, | |
91 unsigned int& level) = 0; | |
92 | |
93 // Sets a volume |scaling| applied to the outgoing signal of a specific | |
94 // channel. Valid scale range is [0.0, 10.0]. | |
95 virtual int SetChannelOutputVolumeScaling(int channel, float scaling) = 0; | |
96 | |
97 // Gets the current volume scaling for a specified |channel|. | |
98 virtual int GetChannelOutputVolumeScaling(int channel, float& scaling) = 0; | |
99 | |
100 // Scales volume of the |left| and |right| channels independently. | |
101 // Valid scale range is [0.0, 1.0]. | |
102 virtual int SetOutputVolumePan(int channel, float left, float right) = 0; | |
103 | |
104 // Gets the current left and right scaling factors. | |
105 virtual int GetOutputVolumePan(int channel, float& left, float& right) = 0; | |
106 | |
107 protected: | |
108 VoEVolumeControl(){}; | |
109 virtual ~VoEVolumeControl(){}; | |
110 }; | |
111 | |
112 } // namespace webrtc | |
113 | |
114 #endif // #ifndef WEBRTC_VOICE_ENGINE_VOE_VOLUME_CONTROL_H | |
OLD | NEW |