Chromium Code Reviews| 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 "media/filters/audio_renderer_impl.h" | 5 #include "media/filters/audio_renderer_impl.h" |
| 6 | 6 |
| 7 #include <math.h> | 7 #include <math.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/callback_helpers.h" | 11 #include "base/callback_helpers.h" |
| 12 #include "base/logging.h" | 12 #include "base/logging.h" |
| 13 #include "media/audio/audio_util.h" | 13 #include "media/audio/audio_util.h" |
| 14 | 14 |
| 15 namespace media { | 15 namespace media { |
| 16 | 16 |
| 17 AudioRendererImpl::AudioRendererImpl(media::AudioRendererSink* sink) | 17 AudioRendererImpl::AudioRendererImpl(media::AudioRendererSink* sink) |
| 18 : state_(kUninitialized), | 18 : state_(kUninitialized), |
| 19 pending_read_(false), | 19 pending_read_(false), |
| 20 received_end_of_stream_(false), | 20 received_end_of_stream_(false), |
| 21 rendered_end_of_stream_(false), | 21 rendered_end_of_stream_(false), |
| 22 audio_time_buffered_(kNoTimestamp()), | 22 audio_time_buffered_(kNoTimestamp()), |
| 23 current_time_(kNoTimestamp()), | 23 current_time_(kNoTimestamp()), |
| 24 bytes_per_frame_(0), | 24 bytes_per_frame_(0), |
| 25 bytes_per_second_(0), | 25 bytes_per_second_(0), |
| 26 stopped_(false), | 26 stopped_(false), |
| 27 sink_(sink), | 27 sink_(sink), |
| 28 is_initialized_(false), | 28 is_initialized_(false), |
| 29 underflow_disabled_(false), | 29 underflow_disabled_(false) { |
| 30 read_cb_(base::Bind(&AudioRendererImpl::DecodedAudioReady, | |
| 31 base::Unretained(this))) { | |
|
Ami GONE FROM CHROMIUM
2012/08/17 23:46:03
Unretained(this) for *speed*.
scherkus (not reviewing)
2012/08/17 23:51:54
I don't know why I did this. Must have been smokin
| |
| 32 } | 30 } |
| 33 | 31 |
| 34 void AudioRendererImpl::Play(const base::Closure& callback) { | 32 void AudioRendererImpl::Play(const base::Closure& callback) { |
| 35 { | 33 { |
| 36 base::AutoLock auto_lock(lock_); | 34 base::AutoLock auto_lock(lock_); |
| 37 DCHECK_EQ(kPaused, state_); | 35 DCHECK_EQ(kPaused, state_); |
| 38 state_ = kPlaying; | 36 state_ = kPlaying; |
| 39 callback.Run(); | 37 callback.Run(); |
| 40 } | 38 } |
| 41 | 39 |
| (...skipping 243 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 285 case kStopped: | 283 case kStopped: |
| 286 return; | 284 return; |
| 287 } | 285 } |
| 288 } | 286 } |
| 289 | 287 |
| 290 void AudioRendererImpl::ScheduleRead_Locked() { | 288 void AudioRendererImpl::ScheduleRead_Locked() { |
| 291 lock_.AssertAcquired(); | 289 lock_.AssertAcquired(); |
| 292 if (pending_read_ || state_ == kPaused) | 290 if (pending_read_ || state_ == kPaused) |
| 293 return; | 291 return; |
| 294 pending_read_ = true; | 292 pending_read_ = true; |
| 295 decoder_->Read(read_cb_); | 293 decoder_->Read(base::Bind(&AudioRendererImpl::DecodedAudioReady, this)); |
| 296 } | 294 } |
| 297 | 295 |
| 298 void AudioRendererImpl::SetPlaybackRate(float playback_rate) { | 296 void AudioRendererImpl::SetPlaybackRate(float playback_rate) { |
| 299 DCHECK_LE(0.0f, playback_rate); | 297 DCHECK_LE(0.0f, playback_rate); |
| 300 | 298 |
| 301 if (!stopped_) { | 299 if (!stopped_) { |
| 302 // We have two cases here: | 300 // We have two cases here: |
| 303 // Play: GetPlaybackRate() == 0.0 && playback_rate != 0.0 | 301 // Play: GetPlaybackRate() == 0.0 && playback_rate != 0.0 |
| 304 // Pause: GetPlaybackRate() != 0.0 && playback_rate == 0.0 | 302 // Pause: GetPlaybackRate() != 0.0 && playback_rate == 0.0 |
| 305 if (GetPlaybackRate() == 0.0f && playback_rate != 0.0f) { | 303 if (GetPlaybackRate() == 0.0f && playback_rate != 0.0f) { |
| (...skipping 225 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 531 case kUnderflow: | 529 case kUnderflow: |
| 532 case kRebuffering: | 530 case kRebuffering: |
| 533 case kStopped: | 531 case kStopped: |
| 534 if (status != PIPELINE_OK) | 532 if (status != PIPELINE_OK) |
| 535 error_cb_.Run(status); | 533 error_cb_.Run(status); |
| 536 return; | 534 return; |
| 537 } | 535 } |
| 538 } | 536 } |
| 539 | 537 |
| 540 } // namespace media | 538 } // namespace media |
| OLD | NEW |