blob: e4a281aec21dd870fbfb9d542e13ff36a137012a [file] [log] [blame]
solenberg566ef242015-11-06 15:34:49 -08001/*
2 * Copyright (c) 2015 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 */
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020010#ifndef CALL_AUDIO_STATE_H_
11#define CALL_AUDIO_STATE_H_
solenberg566ef242015-11-06 15:34:49 -080012
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020013#include "api/audio/audio_mixer.h"
14#include "rtc_base/refcount.h"
15#include "rtc_base/scoped_ref_ptr.h"
solenberg566ef242015-11-06 15:34:49 -080016
17namespace webrtc {
18
peaha9cc40b2017-06-29 08:32:09 -070019class AudioProcessing;
Fredrik Solenberg63e60722017-11-20 22:12:21 +010020class AudioTransport;
solenberg566ef242015-11-06 15:34:49 -080021class VoiceEngine;
22
Fredrik Solenberga4527c82015-12-03 13:06:20 +010023// WORK IN PROGRESS
24// This class is under development and is not yet intended for for use outside
25// of WebRtc/Libjingle. Please use the VoiceEngine API instead.
26// See: https://bugs.chromium.org/p/webrtc/issues/detail?id=4690
27
solenberg566ef242015-11-06 15:34:49 -080028// AudioState holds the state which must be shared between multiple instances of
29// webrtc::Call for audio processing purposes.
30class AudioState : public rtc::RefCountInterface {
31 public:
32 struct Config {
33 // VoiceEngine used for audio streams and audio/video synchronization.
34 // AudioState will tickle the VoE refcount to keep it alive for as long as
35 // the AudioState itself.
36 VoiceEngine* voice_engine = nullptr;
37
aleloi81da4882016-11-08 04:26:30 -080038 // The audio mixer connected to active receive streams. One per
39 // AudioState.
40 rtc::scoped_refptr<AudioMixer> audio_mixer;
peaha9cc40b2017-06-29 08:32:09 -070041
42 // The audio processing module.
43 rtc::scoped_refptr<webrtc::AudioProcessing> audio_processing;
solenberg566ef242015-11-06 15:34:49 -080044 };
45
peaha9cc40b2017-06-29 08:32:09 -070046 virtual AudioProcessing* audio_processing() = 0;
Fredrik Solenberg63e60722017-11-20 22:12:21 +010047 virtual AudioTransport* audio_transport() = 0;
peaha9cc40b2017-06-29 08:32:09 -070048
henrika5f6bf242017-11-01 11:06:56 +010049 // Enable/disable playout of the audio channels. Enabled by default.
50 // This will stop playout of the underlying audio device but start a task
51 // which will poll for audio data every 10ms to ensure that audio processing
52 // happens and the audio stats are updated.
53 virtual void SetPlayout(bool enabled) = 0;
54
55 // Enable/disable recording of the audio channels. Enabled by default.
56 // This will stop recording of the underlying audio device and no audio
57 // packets will be encoded or transmitted.
58 virtual void SetRecording(bool enabled) = 0;
59
solenberg566ef242015-11-06 15:34:49 -080060 // TODO(solenberg): Replace scoped_refptr with shared_ptr once we can use it.
61 static rtc::scoped_refptr<AudioState> Create(
62 const AudioState::Config& config);
63
64 virtual ~AudioState() {}
65};
66} // namespace webrtc
67
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020068#endif // CALL_AUDIO_STATE_H_