Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(95)

Side by Side Diff: webrtc/modules/audio_mixer/audio_mixer_impl.h

Issue 2396483002: Made MixerAudioSource a pure interface. (Closed)
Patch Set: Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved. 2 * Copyright (c) 2012 The WebRTC project authors. All Rights Reserved.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license 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 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 6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may 7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree. 8 * be found in the AUTHORS file in the root of the source tree.
9 */ 9 */
10 10
11 #ifndef WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_ 11 #ifndef WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_
12 #define WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_ 12 #define WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_
13 13
14 #include <map> 14 #include <map>
15 #include <memory> 15 #include <memory>
16 #include <vector> 16 #include <vector>
17 17
18 #include "webrtc/base/gtest_prod_util.h"
18 #include "webrtc/base/thread_annotations.h" 19 #include "webrtc/base/thread_annotations.h"
19 #include "webrtc/base/thread_checker.h" 20 #include "webrtc/base/thread_checker.h"
20 #include "webrtc/engine_configurations.h" 21 #include "webrtc/engine_configurations.h"
21 #include "webrtc/modules/audio_mixer/audio_mixer.h" 22 #include "webrtc/modules/audio_mixer/audio_mixer.h"
22 #include "webrtc/modules/audio_mixer/audio_mixer_defines.h" 23 #include "webrtc/modules/audio_mixer/audio_mixer_defines.h"
24 #include "webrtc/modules/audio_mixer/audio_source_with_mix_status.h"
23 #include "webrtc/modules/audio_processing/include/audio_processing.h" 25 #include "webrtc/modules/audio_processing/include/audio_processing.h"
24 #include "webrtc/modules/include/module_common_types.h" 26 #include "webrtc/modules/include/module_common_types.h"
25 #include "webrtc/system_wrappers/include/critical_section_wrapper.h" 27 #include "webrtc/system_wrappers/include/critical_section_wrapper.h"
26 #include "webrtc/voice_engine/level_indicator.h" 28 #include "webrtc/voice_engine/level_indicator.h"
27 29
28 namespace webrtc { 30 namespace webrtc {
29 31
30 typedef std::vector<AudioFrame*> AudioFrameList; 32 typedef std::vector<AudioFrame*> AudioFrameList;
31 typedef std::vector<MixerAudioSource*> MixerAudioSourceList; 33 typedef std::vector<AudioSourceWithMixStatus> MixerAudioSourceList;
aleloi 2016/10/04 13:37:17 Instead of storing lists of participant pointers,
32 34
33 class AudioMixerImpl : public AudioMixer { 35 class AudioMixerImpl : public AudioMixer {
34 public: 36 public:
35 // AudioProcessing only accepts 10 ms frames. 37 // AudioProcessing only accepts 10 ms frames.
36 static const int kFrameDurationInMs = 10; 38 static const int kFrameDurationInMs = 10;
37 39
38 static std::unique_ptr<AudioMixer> Create(int id); 40 static std::unique_ptr<AudioMixerImpl> Create(int id);
aleloi 2016/10/04 13:37:16 In order to allow the tests to access an AudioMixe
ivoc 2016/10/04 20:39:29 Isn't this public already?
39 41
40 ~AudioMixerImpl() override; 42 ~AudioMixerImpl() override;
41 43
42 // AudioMixer functions 44 // AudioMixer functions
43 int32_t SetMixabilityStatus(MixerAudioSource* audio_source, 45 int32_t SetMixabilityStatus(MixerAudioSource* audio_source,
44 bool mixable) override; 46 bool mixable) override;
45 bool MixabilityStatus(const MixerAudioSource& audio_source) const override; 47 bool MixabilityStatus(const MixerAudioSource& audio_source) const override;
46 int32_t SetAnonymousMixabilityStatus(MixerAudioSource* audio_source, 48 int32_t SetAnonymousMixabilityStatus(MixerAudioSource* audio_source,
47 bool mixable) override; 49 bool mixable) override;
48 void Mix(int sample_rate, 50 void Mix(int sample_rate,
49 size_t number_of_channels, 51 size_t number_of_channels,
50 AudioFrame* audio_frame_for_mixing) override; 52 AudioFrame* audio_frame_for_mixing) override;
51 bool AnonymousMixabilityStatus( 53 bool AnonymousMixabilityStatus(
52 const MixerAudioSource& audio_source) const override; 54 const MixerAudioSource& audio_source) const override;
53 55
56 bool GetAudioSourceMixabilityStatus(MixerAudioSource* participant);
57
aleloi 2016/10/04 13:37:16 Forgot to add a comment, see the next patch set.
54 private: 58 private:
55 AudioMixerImpl(int id, std::unique_ptr<AudioProcessing> limiter); 59 AudioMixerImpl(int id, std::unique_ptr<AudioProcessing> limiter);
56 60
57 // Set/get mix frequency 61 // Set/get mix frequency
58 int32_t SetOutputFrequency(const Frequency& frequency); 62 int32_t SetOutputFrequency(const Frequency& frequency);
59 Frequency OutputFrequency() const; 63 Frequency OutputFrequency() const;
60 64
61 // Compute what audio sources to mix from audio_source_list_. Ramp 65 // Compute what audio sources to mix from audio_source_list_. Ramp
62 // in and out. Update mixed status. Mixes up to 66 // in and out. Update mixed status. Mixes up to
63 // kMaximumAmountOfMixedAudioSources audio sources. 67 // kMaximumAmountOfMixedAudioSources audio sources.
64 AudioFrameList GetNonAnonymousAudio() const EXCLUSIVE_LOCKS_REQUIRED(crit_); 68 AudioFrameList GetNonAnonymousAudio() EXCLUSIVE_LOCKS_REQUIRED(crit_);
aleloi 2016/10/04 13:37:16 This function sets the mixed status of an AudioSou
65 69
66 // Return the AudioFrames that should be mixed anonymously. Ramp in 70 // Return the AudioFrames that should be mixed anonymously. Ramp in
67 // and out. Update mixed status. 71 // and out. Update mixed status.
68 AudioFrameList GetAnonymousAudio() const EXCLUSIVE_LOCKS_REQUIRED(crit_); 72 AudioFrameList GetAnonymousAudio() EXCLUSIVE_LOCKS_REQUIRED(crit_);
aleloi 2016/10/04 13:37:16 Same for this one.
69 73
70 // This function returns true if it finds the MixerAudioSource in the 74 // This function returns true if it finds the MixerAudioSource in the
71 // specified list of MixerAudioSources. 75 // specified list of MixerAudioSources.
72 bool IsAudioSourceInList(const MixerAudioSource& audio_source, 76 bool IsAudioSourceInList(const MixerAudioSource& audio_source,
73 const MixerAudioSourceList& audio_source_list) const; 77 const MixerAudioSourceList& audio_source_list) const;
74 78
75 // Add/remove the MixerAudioSource to the specified 79 // Add/remove the MixerAudioSource to the specified
76 // MixerAudioSource list. 80 // MixerAudioSource list.
77 bool AddAudioSourceToList(MixerAudioSource* audio_source, 81 bool AddAudioSourceToList(MixerAudioSource* audio_source,
78 MixerAudioSourceList* audio_source_list) const; 82 MixerAudioSourceList* audio_source_list) const;
79 bool RemoveAudioSourceFromList(MixerAudioSource* remove_audio_source, 83 bool RemoveAudioSourceFromList(MixerAudioSource* remove_audio_source,
80 MixerAudioSourceList* audio_source_list) const; 84 MixerAudioSourceList* audio_source_list) const;
81 85
82 bool LimitMixedAudio(AudioFrame* mixed_audio) const; 86 bool LimitMixedAudio(AudioFrame* mixed_audio) const;
83 87
84 // Output level functions for VoEVolumeControl. 88 // Output level functions for VoEVolumeControl.
85 int GetOutputAudioLevel() override; 89 int GetOutputAudioLevel() override;
86 90
87 int GetOutputAudioLevelFullRange() override; 91 int GetOutputAudioLevelFullRange() override;
88 92
93 AudioSourceWithMixStatus* GetSourceWithStatus(MixerAudioSource* audio_source);
94
aleloi 2016/10/04 13:37:16 Comment added in next patch set.
89 rtc::CriticalSection crit_; 95 rtc::CriticalSection crit_;
90 96
91 const int32_t id_; 97 const int32_t id_;
92 98
93 // The current sample frequency and sample size when mixing. 99 // The current sample frequency and sample size when mixing.
94 Frequency output_frequency_ ACCESS_ON(&thread_checker_); 100 Frequency output_frequency_ ACCESS_ON(&thread_checker_);
95 size_t sample_size_ ACCESS_ON(&thread_checker_); 101 size_t sample_size_ ACCESS_ON(&thread_checker_);
96 102
97 // List of all audio sources. Note all lists are disjunct 103 // List of all audio sources. Note all lists are disjunct
98 MixerAudioSourceList audio_source_list_ GUARDED_BY(crit_); // May be mixed. 104 MixerAudioSourceList audio_source_list_ GUARDED_BY(crit_); // May be mixed.
(...skipping 11 matching lines...) Expand all
110 // Ensures that Mix is called from the same thread. 116 // Ensures that Mix is called from the same thread.
111 rtc::ThreadChecker thread_checker_; 117 rtc::ThreadChecker thread_checker_;
112 118
113 // Used for inhibiting saturation in mixing. 119 // Used for inhibiting saturation in mixing.
114 std::unique_ptr<AudioProcessing> limiter_ ACCESS_ON(&thread_checker_); 120 std::unique_ptr<AudioProcessing> limiter_ ACCESS_ON(&thread_checker_);
115 121
116 // Measures audio level for the combined signal. 122 // Measures audio level for the combined signal.
117 voe::AudioLevel audio_level_ ACCESS_ON(&thread_checker_); 123 voe::AudioLevel audio_level_ ACCESS_ON(&thread_checker_);
118 124
119 RTC_DISALLOW_COPY_AND_ASSIGN(AudioMixerImpl); 125 RTC_DISALLOW_COPY_AND_ASSIGN(AudioMixerImpl);
126 FRIEND_TEST_ALL_PREFIXES(AudioMixerTest, Create);
aleloi 2016/10/04 13:37:16 Alternatively, we could make ::Create public.
120 }; 127 };
121 } // namespace webrtc 128 } // namespace webrtc
122 129
123 #endif // WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_ 130 #endif // WEBRTC_MODULES_AUDIO_MIXER_AUDIO_MIXER_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698