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..dcda135a2eb21a620c6298053ff11789f7ea8056 |
| --- /dev/null |
| +++ b/media/audio/virtual_audio_output_stream.cc |
| @@ -0,0 +1,81 @@ |
| +// 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" |
| +#include "media/audio/virtual_audio_input_stream.h" |
| + |
| +namespace media { |
| + |
| +// static |
| +VirtualAudioOutputStream* VirtualAudioOutputStream::MakeStream( |
| + AudioManagerBase* manager, const AudioParameters& params, |
| + VirtualAudioInputStream* target) { |
| + return new VirtualAudioOutputStream(manager, params, target); |
| +} |
| + |
| +VirtualAudioOutputStream::VirtualAudioOutputStream( |
| + AudioManagerBase* manager, const AudioParameters& params, |
| + VirtualAudioInputStream* target) |
| + : audio_manager_(manager), |
| + callback_(NULL), |
| + params_(params), |
| + target_input_stream_(target), |
| + volume_(1.0f), |
| + attached_(false) { |
| +} |
| + |
| +VirtualAudioOutputStream::~VirtualAudioOutputStream() { |
| + DCHECK(!callback_); |
|
DaleCurtis
2012/11/28 23:43:18
DCHECK(!attached_) ?
justinlin
2012/11/29 10:08:33
Done.
|
| +} |
| + |
| +bool VirtualAudioOutputStream::Open() { |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + DCHECK(!attached_); |
| + target_input_stream_->AddOutputStream(this, params_); |
| + attached_ = true; |
| + 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(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + DCHECK(!callback_); |
| + target_input_stream_->RemoveOutputStream(this); |
|
DaleCurtis
2012/11/28 23:43:18
If attached_, attached_ = false ? Also you could m
justinlin
2012/11/29 10:08:33
Done.
|
| + 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) { |
| + DCHECK(audio_manager_->GetMessageLoop()->BelongsToCurrentThread()); |
| + if (!callback_) |
| + return 0; |
| + |
| + int frames = callback_->OnMoreData(audio_bus, AudioBuffersState()); |
| + if (frames < audio_bus->frames()) |
| + audio_bus->ZeroFramesPartial(frames, audio_bus->frames() - frames); |
| + |
| + return frames > 0 ? 1 : 0; |
|
DaleCurtis
2012/11/28 23:43:18
return volume_ since you're tracking it?
justinlin
2012/11/29 10:08:33
Done.
|
| +} |
| + |
| +} // namespace media |