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

Side by Side Diff: webrtc/modules/audio_mixer/audio_mixer.cc

Issue 2111293003: Removed callback between old AudioConferenceMixer and OutputMixer. The audio frame with mixed audio… (Closed) Base URL: https://chromium.googlesource.com/external/webrtc.git@new_mixer_format
Patch Set: Added variable name. Created 4 years, 5 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 #include "webrtc/modules/audio_mixer/audio_mixer.h" 11 #include "webrtc/modules/audio_mixer/audio_mixer.h"
12 12
13 #include "webrtc/base/format_macros.h" 13 #include "webrtc/base/format_macros.h"
14 #include "webrtc/modules/audio_processing/include/audio_processing.h" 14 #include "webrtc/modules/audio_processing/include/audio_processing.h"
15 #include "webrtc/modules/utility/include/audio_frame_operations.h" 15 #include "webrtc/modules/utility/include/audio_frame_operations.h"
16 #include "webrtc/system_wrappers/include/file_wrapper.h" 16 #include "webrtc/system_wrappers/include/file_wrapper.h"
17 #include "webrtc/system_wrappers/include/trace.h" 17 #include "webrtc/system_wrappers/include/trace.h"
18 #include "webrtc/voice_engine/include/voe_external_media.h" 18 #include "webrtc/voice_engine/include/voe_external_media.h"
19 #include "webrtc/voice_engine/statistics.h" 19 #include "webrtc/voice_engine/statistics.h"
20 #include "webrtc/voice_engine/utility.h" 20 #include "webrtc/voice_engine/utility.h"
21 21
22 namespace webrtc { 22 namespace webrtc {
23 namespace voe { 23 namespace voe {
24 24
25 void AudioMixer::NewMixedAudio(int32_t id,
26 const AudioFrame& generalAudioFrame,
27 const AudioFrame** uniqueAudioFrames,
28 uint32_t size) {
29 WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId, -1),
30 "AudioMixer::NewMixedAudio(id=%d, size=%u)", id, size);
31
32 _audioFrame.CopyFrom(generalAudioFrame);
33 _audioFrame.id_ = id;
34 }
35
36 void AudioMixer::PlayNotification(int32_t id, uint32_t durationMs) { 25 void AudioMixer::PlayNotification(int32_t id, uint32_t durationMs) {
37 WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId, -1), 26 WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId, -1),
38 "AudioMixer::PlayNotification(id=%d, durationMs=%d)", id, 27 "AudioMixer::PlayNotification(id=%d, durationMs=%d)", id,
39 durationMs); 28 durationMs);
40 // Not implement yet 29 // Not implement yet
41 } 30 }
42 31
43 void AudioMixer::RecordNotification(int32_t id, uint32_t durationMs) { 32 void AudioMixer::RecordNotification(int32_t id, uint32_t durationMs) {
44 WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId, -1), 33 WEBRTC_TRACE(kTraceStream, kTraceVoice, VoEId(_instanceId, -1),
45 "AudioMixer::RecordNotification(id=%d, durationMs=%d)", id, 34 "AudioMixer::RecordNotification(id=%d, durationMs=%d)", id,
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 _instanceId(instanceId), 75 _instanceId(instanceId),
87 _externalMediaCallbackPtr(NULL), 76 _externalMediaCallbackPtr(NULL),
88 _externalMedia(false), 77 _externalMedia(false),
89 _panLeft(1.0f), 78 _panLeft(1.0f),
90 _panRight(1.0f), 79 _panRight(1.0f),
91 _mixingFrequencyHz(8000), 80 _mixingFrequencyHz(8000),
92 _outputFileRecorderPtr(NULL), 81 _outputFileRecorderPtr(NULL),
93 _outputFileRecording(false) { 82 _outputFileRecording(false) {
94 WEBRTC_TRACE(kTraceMemory, kTraceVoice, VoEId(_instanceId, -1), 83 WEBRTC_TRACE(kTraceMemory, kTraceVoice, VoEId(_instanceId, -1),
95 "AudioMixer::AudioMixer() - ctor"); 84 "AudioMixer::AudioMixer() - ctor");
96
97 if (_mixerModule.RegisterMixedStreamCallback(this) == -1) {
98 WEBRTC_TRACE(kTraceError, kTraceVoice, VoEId(_instanceId, -1),
99 "AudioMixer::AudioMixer() failed to register mixer"
100 "callbacks");
101 }
102 } 85 }
103 86
104 void AudioMixer::Destroy(AudioMixer*& mixer) { 87 void AudioMixer::Destroy(AudioMixer*& mixer) {
105 if (mixer) { 88 if (mixer) {
106 delete mixer; 89 delete mixer;
107 mixer = NULL; 90 mixer = NULL;
108 } 91 }
109 } 92 }
110 93
111 AudioMixer::~AudioMixer() { 94 AudioMixer::~AudioMixer() {
112 WEBRTC_TRACE(kTraceMemory, kTraceVoice, VoEId(_instanceId, -1), 95 WEBRTC_TRACE(kTraceMemory, kTraceVoice, VoEId(_instanceId, -1),
113 "AudioMixer::~AudioMixer() - dtor"); 96 "AudioMixer::~AudioMixer() - dtor");
114 if (_externalMedia) { 97 if (_externalMedia) {
115 DeRegisterExternalMediaProcessing(); 98 DeRegisterExternalMediaProcessing();
116 } 99 }
117 { 100 {
118 rtc::CritScope cs(&_fileCritSect); 101 rtc::CritScope cs(&_fileCritSect);
119 if (_outputFileRecorderPtr) { 102 if (_outputFileRecorderPtr) {
120 _outputFileRecorderPtr->RegisterModuleFileCallback(NULL); 103 _outputFileRecorderPtr->RegisterModuleFileCallback(NULL);
121 _outputFileRecorderPtr->StopRecording(); 104 _outputFileRecorderPtr->StopRecording();
122 FileRecorder::DestroyFileRecorder(_outputFileRecorderPtr); 105 FileRecorder::DestroyFileRecorder(_outputFileRecorderPtr);
123 _outputFileRecorderPtr = NULL; 106 _outputFileRecorderPtr = NULL;
124 } 107 }
125 } 108 }
126 _mixerModule.UnRegisterMixedStreamCallback();
127 delete &_mixerModule; 109 delete &_mixerModule;
128 } 110 }
129 111
130 int32_t AudioMixer::SetEngineInformation(voe::Statistics& engineStatistics) { 112 int32_t AudioMixer::SetEngineInformation(voe::Statistics& engineStatistics) {
131 WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId, -1), 113 WEBRTC_TRACE(kTraceInfo, kTraceVoice, VoEId(_instanceId, -1),
132 "AudioMixer::SetEngineInformation()"); 114 "AudioMixer::SetEngineInformation()");
133 _engineStatisticsPtr = &engineStatistics; 115 _engineStatisticsPtr = &engineStatistics;
134 return 0; 116 return 0;
135 } 117 }
136 118
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
171 bool mixable) { 153 bool mixable) {
172 return _mixerModule.SetMixabilityStatus(&participant, mixable); 154 return _mixerModule.SetMixabilityStatus(&participant, mixable);
173 } 155 }
174 156
175 int32_t AudioMixer::SetAnonymousMixabilityStatus(MixerAudioSource& participant, 157 int32_t AudioMixer::SetAnonymousMixabilityStatus(MixerAudioSource& participant,
176 bool mixable) { 158 bool mixable) {
177 return _mixerModule.SetAnonymousMixabilityStatus(&participant, mixable); 159 return _mixerModule.SetAnonymousMixabilityStatus(&participant, mixable);
178 } 160 }
179 161
180 int32_t AudioMixer::MixActiveChannels() { 162 int32_t AudioMixer::MixActiveChannels() {
181 _mixerModule.Process(); 163 _mixerModule.Mix(&_audioFrame);
tommi 2016/07/06 19:42:17 On what thread is this method called? Since there
aleloi 2016/07/07 09:20:16 Every method related to mixing in OutputMixer and
182 return 0; 164 return 0;
183 } 165 }
184 166
185 int AudioMixer::GetSpeechOutputLevel(uint32_t& level) { 167 int AudioMixer::GetSpeechOutputLevel(uint32_t& level) {
186 int8_t currentLevel = _audioLevel.Level(); 168 int8_t currentLevel = _audioLevel.Level();
187 level = static_cast<uint32_t>(currentLevel); 169 level = static_cast<uint32_t>(currentLevel);
188 WEBRTC_TRACE(kTraceStateInfo, kTraceVoice, VoEId(_instanceId, -1), 170 WEBRTC_TRACE(kTraceStateInfo, kTraceVoice, VoEId(_instanceId, -1),
189 "GetSpeechOutputLevel() => level=%u", level); 171 "GetSpeechOutputLevel() => level=%u", level);
190 return 0; 172 return 0;
191 } 173 }
(...skipping 250 matching lines...) Expand 10 before | Expand all | Expand 10 after
442 } 424 }
443 } 425 }
444 426
445 // --- Measure audio level (0-9) for the combined signal 427 // --- Measure audio level (0-9) for the combined signal
446 _audioLevel.ComputeLevel(_audioFrame); 428 _audioLevel.ComputeLevel(_audioFrame);
447 429
448 return 0; 430 return 0;
449 } 431 }
450 } // namespace voe 432 } // namespace voe
451 } // namespace webrtc 433 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698