Chromium Code Reviews| Index: media/audio/virtual_audio_output_stream.cc |
| diff --git a/media/audio/virtual_audio_output_stream.cc b/media/audio/virtual_audio_output_stream.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..765d86f8dcdf5de4a5262725164d205db21dbfa4 |
| --- /dev/null |
| +++ b/media/audio/virtual_audio_output_stream.cc |
| @@ -0,0 +1,69 @@ |
| +// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "media/audio/virtual_audio_output_stream.h" |
| + |
| +#include "base/message_loop.h" |
| +#include "media/audio/audio_manager_base.h" |
| + |
| +namespace media { |
| + |
| +// static |
| +VirtualAudioOutputStream* VirtualAudioOutputStream::MakeStream( |
| + AudioManagerBase* manager, const AudioParameters& params) { |
| + return new VirtualAudioOutputStream(manager, params); |
| +} |
| + |
| +VirtualAudioOutputStream::VirtualAudioOutputStream( |
| + AudioManagerBase* manager, const AudioParameters& params) |
| + : audio_manager_(manager), |
| + callback_(NULL), |
| + volume_(1.0f) { |
| +} |
| + |
| +VirtualAudioOutputStream::~VirtualAudioOutputStream() { |
| + DCHECK(!callback_); |
| +} |
| + |
| +bool VirtualAudioOutputStream::Open() { |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + return true; |
| +} |
| + |
| +void VirtualAudioOutputStream::Start(AudioSourceCallback* callback) { |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + callback_ = callback; |
| +} |
| + |
| +void VirtualAudioOutputStream::Stop() { |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + callback_ = NULL; |
| +} |
| + |
| +void VirtualAudioOutputStream::Close() { |
| + DCHECK(!callback_); |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + audio_manager_->ReleaseOutputStream(this); |
| +} |
| + |
| +void VirtualAudioOutputStream::SetVolume(double volume) { |
| + volume_ = static_cast<float>(volume); |
| +} |
| + |
| +void VirtualAudioOutputStream::GetVolume(double* volume) { |
| + *volume = volume_; |
| +} |
| + |
| +double VirtualAudioOutputStream::ProvideInput( |
| + AudioBus* audio_bus, base::TimeDelta buffer_delay) { |
| + if (callback_ == NULL) |
|
DaleCurtis
2012/11/21 23:45:43
if (!callback)
You need to DCHECK that this is on
justinlin
2012/11/26 20:19:20
Done.
|
| + return 0; |
| + |
| + audio_bus->Zero(); |
|
DaleCurtis
2012/11/21 23:45:43
I'd just ZeroFramesPartial() if frames < audio_bus
justinlin
2012/11/26 20:19:20
Done.
|
| + int frames = callback_->OnMoreData(audio_bus, AudioBuffersState()); |
| + |
| + return frames > 0 ? 1 : 0; |
| +} |
| + |
| +} // namespace media |