1 /* 2 * Copyright (c) 2012 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 // - Support of non-default codecs (e.g. iLBC, iSAC, etc.). 14 // - Voice Activity Detection (VAD) on a per channel basis. 15 // - Possibility to specify how to map received payload types to codecs. 16 // 17 // Usage example, omitting error checking: 18 // 19 // using namespace webrtc; 20 // VoiceEngine* voe = VoiceEngine::Create(); 21 // VoEBase* base = VoEBase::GetInterface(voe); 22 // VoECodec* codec = VoECodec::GetInterface(voe); 23 // base->Init(); 24 // int num_of_codecs = codec->NumOfCodecs() 25 // ... 26 // base->Terminate(); 27 // base->Release(); 28 // codec->Release(); 29 // VoiceEngine::Delete(voe); 30 // 31 #ifndef WEBRTC_VOICE_ENGINE_VOE_CODEC_H 32 #define WEBRTC_VOICE_ENGINE_VOE_CODEC_H 33 34 #include "webrtc/common_types.h" 35 36 namespace webrtc { 37 38 class VoiceEngine; 39 40 class WEBRTC_DLLEXPORT VoECodec 41 { 42 public: 43 // Factory for the VoECodec sub-API. Increases an internal 44 // reference counter if successful. Returns NULL if the API is not 45 // supported or if construction fails. 46 static VoECodec* GetInterface(VoiceEngine* voiceEngine); 47 48 // Releases the VoECodec sub-API and decreases an internal 49 // reference counter. Returns the new reference count. This value should 50 // be zero for all sub-API:s before the VoiceEngine object can be safely 51 // deleted. 52 virtual int Release() = 0; 53 54 // Gets the number of supported codecs. 55 virtual int NumOfCodecs() = 0; 56 57 // Get the |codec| information for a specified list |index|. 58 virtual int GetCodec(int index, CodecInst& codec) = 0; 59 60 // Sets the |codec| for the |channel| to be used for sending. 61 virtual int SetSendCodec(int channel, const CodecInst& codec) = 0; 62 63 // Gets the |codec| parameters for the sending codec on a specified 64 // |channel|. 65 virtual int GetSendCodec(int channel, CodecInst& codec) = 0; 66 67 // Sets the |codec| as secondary codec for |channel|. Registering a 68 // secondary send codec enables dual-streaming. In dual-streaming mode, 69 // payloads of the primary and the secondary codecs are packed in RED 70 // payloads with |red_payload_type| as payload type. The Secondary codec 71 // MUST have the same sampling rate as the primary codec, otherwise the 72 // codec cannot be registered and -1 is returned. This method fails if a 73 // primary codec is not yet set. 74 virtual int SetSecondarySendCodec(int channel, const CodecInst& codec, 75 int red_payload_type) = 0; 76 77 // Removes the secondary codec from |channel|. This will terminate 78 // dual-streaming. 79 virtual int RemoveSecondarySendCodec(int channel) = 0; 80 81 // Gets |codec| which is used as secondary codec in |channel|. 82 virtual int GetSecondarySendCodec(int channel, CodecInst& codec) = 0; 83 84 // Gets the currently received |codec| for a specific |channel|. 85 virtual int GetRecCodec(int channel, CodecInst& codec) = 0; 86 87 // Sets the dynamic payload type number for a particular |codec| or 88 // disables (ignores) a codec for receiving. For instance, when receiving 89 // an invite from a SIP-based client, this function can be used to change 90 // the dynamic payload type number to match that in the INVITE SDP- 91 // message. The utilized parameters in the |codec| structure are: 92 // plname, plfreq, pltype and channels. 93 virtual int SetRecPayloadType(int channel, const CodecInst& codec) = 0; 94 95 // Gets the actual payload type that is set for receiving a |codec| on a 96 // |channel|. The value it retrieves will either be the default payload 97 // type, or a value earlier set with SetRecPayloadType(). 98 virtual int GetRecPayloadType(int channel, CodecInst& codec) = 0; 99 100 // Sets the payload |type| for the sending of SID-frames with background 101 // noise estimation during silence periods detected by the VAD. 102 virtual int SetSendCNPayloadType( 103 int channel, int type, PayloadFrequencies frequency = kFreq16000Hz) = 0; 104 105 // Sets the codec internal FEC (forward error correction) status for a 106 // specified |channel|. Returns 0 if success, and -1 if failed. 107 // TODO(minyue): Make SetFECStatus() pure virtual when fakewebrtcvoiceengine 108 // in talk is ready. SetFECStatus(int channel,bool enable)109 virtual int SetFECStatus(int channel, bool enable) { return -1; } 110 111 // Gets the codec internal FEC status for a specified |channel|. Returns 0 112 // with the status stored in |enabled| if success, and -1 if encountered 113 // error. 114 // TODO(minyue): Make GetFECStatus() pure virtual when fakewebrtcvoiceengine 115 // in talk is ready. GetFECStatus(int channel,bool & enabled)116 virtual int GetFECStatus(int channel, bool& enabled) { return -1; } 117 118 // Sets the VAD/DTX (silence suppression) status and |mode| for a 119 // specified |channel|. Disabling VAD (through |enable|) will also disable 120 // DTX; it is not necessary to explictly set |disableDTX| in this case. 121 virtual int SetVADStatus(int channel, bool enable, 122 VadModes mode = kVadConventional, 123 bool disableDTX = false) = 0; 124 125 // Gets the VAD/DTX status and |mode| for a specified |channel|. 126 virtual int GetVADStatus(int channel, bool& enabled, VadModes& mode, 127 bool& disabledDTX) = 0; 128 129 // If send codec is Opus on a specified |channel|, sets the maximum playback 130 // rate the receiver will render: |frequency_hz| (in Hz). 131 // TODO(minyue): Make SetOpusMaxPlaybackRate() pure virtual when 132 // fakewebrtcvoiceengine in talk is ready. SetOpusMaxPlaybackRate(int channel,int frequency_hz)133 virtual int SetOpusMaxPlaybackRate(int channel, int frequency_hz) { 134 return -1; 135 } 136 137 // Don't use. To be removed. SetAMREncFormat(int channel,AmrMode mode)138 virtual int SetAMREncFormat(int channel, AmrMode mode) { return -1; } SetAMRDecFormat(int channel,AmrMode mode)139 virtual int SetAMRDecFormat(int channel, AmrMode mode) { return -1; } SetAMRWbEncFormat(int channel,AmrMode mode)140 virtual int SetAMRWbEncFormat(int channel, AmrMode mode) { return -1; } SetAMRWbDecFormat(int channel,AmrMode mode)141 virtual int SetAMRWbDecFormat(int channel, AmrMode mode) { return -1; } 142 virtual int SetISACInitTargetRate(int channel, int rateBps, 143 bool useFixedFrameSize = false) { return -1; } SetISACMaxRate(int channel,int rateBps)144 virtual int SetISACMaxRate(int channel, int rateBps) { return -1; } SetISACMaxPayloadSize(int channel,int sizeBytes)145 virtual int SetISACMaxPayloadSize(int channel, int sizeBytes) { return -1; } 146 147 protected: VoECodec()148 VoECodec() {} ~VoECodec()149 virtual ~VoECodec() {} 150 }; 151 152 } // namespace webrtc 153 154 #endif // WEBRTC_VOICE_ENGINE_VOE_CODEC_H 155