Home | History | Annotate | Download | only in include
      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 //  - Audio device handling.
     14 //  - Device information.
     15 //  - CPU load monitoring.
     16 //
     17 // Usage example, omitting error checking:
     18 //
     19 //  using namespace webrtc;
     20 //  VoiceEngine* voe = VoiceEngine::Create();
     21 //  VoEBase* base = VoEBase::GetInterface(voe);
     22 //  VoEHardware* hardware  = VoEHardware::GetInterface(voe);
     23 //  base->Init();
     24 //  ...
     25 //  int n_devices = hardware->GetNumOfPlayoutDevices();
     26 //  ...
     27 //  base->Terminate();
     28 //  base->Release();
     29 //  hardware->Release();
     30 //  VoiceEngine::Delete(voe);
     31 //
     32 #ifndef WEBRTC_VOICE_ENGINE_VOE_HARDWARE_H
     33 #define WEBRTC_VOICE_ENGINE_VOE_HARDWARE_H
     34 
     35 #include "webrtc/common_types.h"
     36 
     37 namespace webrtc {
     38 
     39 class VoiceEngine;
     40 
     41 class WEBRTC_DLLEXPORT VoEHardware
     42 {
     43 public:
     44     // Factory for the VoEHardware sub-API. Increases an internal
     45     // reference counter if successful. Returns NULL if the API is not
     46     // supported or if construction fails.
     47     static VoEHardware* GetInterface(VoiceEngine* voiceEngine);
     48 
     49     // Releases the VoEHardware sub-API and decreases an internal
     50     // reference counter. Returns the new reference count. This value should
     51     // be zero for all sub-API:s before the VoiceEngine object can be safely
     52     // deleted.
     53     virtual int Release() = 0;
     54 
     55     // Gets the number of audio devices available for recording.
     56     virtual int GetNumOfRecordingDevices(int& devices) = 0;
     57 
     58     // Gets the number of audio devices available for playout.
     59     virtual int GetNumOfPlayoutDevices(int& devices) = 0;
     60 
     61     // Gets the name of a specific recording device given by an |index|.
     62     // On Windows Vista/7, it also retrieves an additional unique ID
     63     // (GUID) for the recording device.
     64     virtual int GetRecordingDeviceName(int index, char strNameUTF8[128],
     65                                        char strGuidUTF8[128]) = 0;
     66 
     67     // Gets the name of a specific playout device given by an |index|.
     68     // On Windows Vista/7, it also retrieves an additional unique ID
     69     // (GUID) for the playout device.
     70     virtual int GetPlayoutDeviceName(int index, char strNameUTF8[128],
     71                                      char strGuidUTF8[128]) = 0;
     72 
     73     // Sets the audio device used for recording.
     74     virtual int SetRecordingDevice(
     75         int index, StereoChannel recordingChannel = kStereoBoth) = 0;
     76 
     77     // Sets the audio device used for playout.
     78     virtual int SetPlayoutDevice(int index) = 0;
     79 
     80     // Sets the type of audio device layer to use.
     81     virtual int SetAudioDeviceLayer(AudioLayers audioLayer) = 0;
     82 
     83     // Gets the currently used (active) audio device layer.
     84     virtual int GetAudioDeviceLayer(AudioLayers& audioLayer) = 0;
     85 
     86     // Native sample rate controls (samples/sec)
     87     virtual int SetRecordingSampleRate(unsigned int samples_per_sec) = 0;
     88     virtual int RecordingSampleRate(unsigned int* samples_per_sec) const = 0;
     89     virtual int SetPlayoutSampleRate(unsigned int samples_per_sec) = 0;
     90     virtual int PlayoutSampleRate(unsigned int* samples_per_sec) const = 0;
     91 
     92     // To be removed. Don't use.
     93     virtual int EnableBuiltInAEC(bool enable) { return -1; }
     94     virtual bool BuiltInAECIsEnabled() const { return false; }
     95     virtual int GetRecordingDeviceStatus(bool& isAvailable) { return -1; }
     96     virtual int GetPlayoutDeviceStatus(bool& isAvailable) { return -1; }
     97     virtual int ResetAudioDevice() { return -1; }
     98     virtual int AudioDeviceControl(unsigned int par1, unsigned int par2,
     99             unsigned int par3) { return -1; }
    100     virtual int SetLoudspeakerStatus(bool enable) { return -1; }
    101     virtual int GetLoudspeakerStatus(bool& enabled) { return -1; }
    102     virtual int GetCPULoad(int& loadPercent) { return -1; }
    103 
    104 
    105 protected:
    106     VoEHardware() {}
    107     virtual ~VoEHardware() {}
    108 };
    109 
    110 }  // namespace webrtc
    111 
    112 #endif  //  WEBRTC_VOICE_ENGINE_VOE_HARDWARE_H
    113