| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/renderer/media/webrtc_audio_device_impl.h" | 5 #include "content/renderer/media/webrtc_audio_device_impl.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/metrics/histogram.h" | 8 #include "base/metrics/histogram.h" |
| 9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
| 10 #include "base/win/windows_version.h" | 10 #include "base/win/windows_version.h" |
| (...skipping 129 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 140 bytes_per_sample_(0), | 140 bytes_per_sample_(0), |
| 141 initialized_(false), | 141 initialized_(false), |
| 142 playing_(false), | 142 playing_(false), |
| 143 recording_(false), | 143 recording_(false), |
| 144 agc_is_enabled_(false) { | 144 agc_is_enabled_(false) { |
| 145 DVLOG(1) << "WebRtcAudioDeviceImpl::WebRtcAudioDeviceImpl()"; | 145 DVLOG(1) << "WebRtcAudioDeviceImpl::WebRtcAudioDeviceImpl()"; |
| 146 // TODO(henrika): remove this restriction when factory is used for the | 146 // TODO(henrika): remove this restriction when factory is used for the |
| 147 // input side as well. | 147 // input side as well. |
| 148 DCHECK(RenderThreadImpl::current()) << | 148 DCHECK(RenderThreadImpl::current()) << |
| 149 "WebRtcAudioDeviceImpl must be constructed on the render thread"; | 149 "WebRtcAudioDeviceImpl must be constructed on the render thread"; |
| 150 audio_output_device_ = AudioDeviceFactory::Create(); | 150 audio_output_device_ = AudioDeviceFactory::NewOutputDevice(); |
| 151 DCHECK(audio_output_device_); | 151 DCHECK(audio_output_device_); |
| 152 } | 152 } |
| 153 | 153 |
| 154 WebRtcAudioDeviceImpl::~WebRtcAudioDeviceImpl() { | 154 WebRtcAudioDeviceImpl::~WebRtcAudioDeviceImpl() { |
| 155 DVLOG(1) << "WebRtcAudioDeviceImpl::~WebRtcAudioDeviceImpl()"; | 155 DVLOG(1) << "WebRtcAudioDeviceImpl::~WebRtcAudioDeviceImpl()"; |
| 156 if (playing_) | 156 if (playing_) |
| 157 StopPlayout(); | 157 StopPlayout(); |
| 158 if (recording_) | 158 if (recording_) |
| 159 StopRecording(); | 159 StopRecording(); |
| 160 if (initialized_) | 160 if (initialized_) |
| (...skipping 230 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 391 LOG(ERROR) << "Unable to (de)register transport during active media"; | 391 LOG(ERROR) << "Unable to (de)register transport during active media"; |
| 392 return -1; | 392 return -1; |
| 393 } | 393 } |
| 394 audio_transport_callback_ = audio_callback; | 394 audio_transport_callback_ = audio_callback; |
| 395 return 0; | 395 return 0; |
| 396 } | 396 } |
| 397 | 397 |
| 398 int32_t WebRtcAudioDeviceImpl::Init() { | 398 int32_t WebRtcAudioDeviceImpl::Init() { |
| 399 DVLOG(1) << "Init()"; | 399 DVLOG(1) << "Init()"; |
| 400 | 400 |
| 401 // TODO(henrika): After switching to using the AudioDeviceFactory for |
| 402 // instantiating the input device, maybe this isn't a requirement anymore? |
| 401 if (!render_loop_->BelongsToCurrentThread()) { | 403 if (!render_loop_->BelongsToCurrentThread()) { |
| 402 int32_t error = 0; | 404 int32_t error = 0; |
| 403 base::WaitableEvent event(false, false); | 405 base::WaitableEvent event(false, false); |
| 404 // Ensure that we call Init() from the main render thread since | 406 // Ensure that we call Init() from the main render thread since |
| 405 // the audio clients can only be created on this thread. | 407 // the audio clients can only be created on this thread. |
| 406 render_loop_->PostTask( | 408 render_loop_->PostTask( |
| 407 FROM_HERE, | 409 FROM_HERE, |
| 408 base::Bind(&WebRtcAudioDeviceImpl::InitOnRenderThread, | 410 base::Bind(&WebRtcAudioDeviceImpl::InitOnRenderThread, |
| 409 this, &error, &event)); | 411 this, &error, &event)); |
| 410 event.Wait(); | 412 event.Wait(); |
| (...skipping 160 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 571 // after a successful initialization. | 573 // after a successful initialization. |
| 572 output_audio_parameters_.Reset( | 574 output_audio_parameters_.Reset( |
| 573 AudioParameters::AUDIO_PCM_LOW_LATENCY, out_channel_layout, | 575 AudioParameters::AUDIO_PCM_LOW_LATENCY, out_channel_layout, |
| 574 out_sample_rate, 16, out_buffer_size); | 576 out_sample_rate, 16, out_buffer_size); |
| 575 | 577 |
| 576 input_audio_parameters_.Reset( | 578 input_audio_parameters_.Reset( |
| 577 in_format, in_channel_layout, in_sample_rate, | 579 in_format, in_channel_layout, in_sample_rate, |
| 578 16, in_buffer_size); | 580 16, in_buffer_size); |
| 579 | 581 |
| 580 // Create and configure the audio capturing client. | 582 // Create and configure the audio capturing client. |
| 581 audio_input_device_ = new AudioInputDevice( | 583 audio_input_device_ = AudioDeviceFactory::NewInputDevice(); |
| 582 input_audio_parameters_, this, this); | 584 audio_input_device_->Initialize(input_audio_parameters_, this, this); |
| 583 | 585 |
| 584 UMA_HISTOGRAM_ENUMERATION("WebRTC.AudioOutputChannelLayout", | 586 UMA_HISTOGRAM_ENUMERATION("WebRTC.AudioOutputChannelLayout", |
| 585 out_channel_layout, CHANNEL_LAYOUT_MAX); | 587 out_channel_layout, CHANNEL_LAYOUT_MAX); |
| 586 UMA_HISTOGRAM_ENUMERATION("WebRTC.AudioInputChannelLayout", | 588 UMA_HISTOGRAM_ENUMERATION("WebRTC.AudioInputChannelLayout", |
| 587 in_channel_layout, CHANNEL_LAYOUT_MAX); | 589 in_channel_layout, CHANNEL_LAYOUT_MAX); |
| 588 AddHistogramFramesPerBuffer(kAudioOutput, out_buffer_size); | 590 AddHistogramFramesPerBuffer(kAudioOutput, out_buffer_size); |
| 589 AddHistogramFramesPerBuffer(kAudioInput, in_buffer_size); | 591 AddHistogramFramesPerBuffer(kAudioInput, in_buffer_size); |
| 590 | 592 |
| 591 // Configure the audio rendering client. | 593 // Configure the audio rendering client. |
| 592 audio_output_device_->Initialize(output_audio_parameters_, this); | 594 audio_output_device_->Initialize(output_audio_parameters_, this); |
| (...skipping 572 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1165 } | 1167 } |
| 1166 | 1168 |
| 1167 int32_t WebRtcAudioDeviceImpl::GetLoudspeakerStatus(bool* enabled) const { | 1169 int32_t WebRtcAudioDeviceImpl::GetLoudspeakerStatus(bool* enabled) const { |
| 1168 NOTIMPLEMENTED(); | 1170 NOTIMPLEMENTED(); |
| 1169 return -1; | 1171 return -1; |
| 1170 } | 1172 } |
| 1171 | 1173 |
| 1172 void WebRtcAudioDeviceImpl::SetSessionId(int session_id) { | 1174 void WebRtcAudioDeviceImpl::SetSessionId(int session_id) { |
| 1173 session_id_ = session_id; | 1175 session_id_ = session_id; |
| 1174 } | 1176 } |
| OLD | NEW |