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

Side by Side Diff: chromecast/media/cma/base/buffering_state.cc

Issue 509213002: Add a buffering controller for Chromecast. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix bad license header. Created 6 years, 3 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
« no previous file with comments | « chromecast/media/cma/base/buffering_state.h ('k') | chromecast/media/cma/base/cma_logging.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chromecast/media/cma/base/buffering_state.h"
6
7 #include <sstream>
8
9 #include "base/logging.h"
10 #include "media/base/buffers.h"
11
12 namespace chromecast {
13 namespace media {
14
15 BufferingConfig::BufferingConfig(
16 base::TimeDelta low_level_threshold,
17 base::TimeDelta high_level_threshold)
18 : low_level_threshold_(low_level_threshold),
19 high_level_threshold_(high_level_threshold) {
20 }
21
22 BufferingConfig::~BufferingConfig() {
23 }
24
25
26 BufferingState::BufferingState(
27 const scoped_refptr<BufferingConfig>& config,
28 const base::Closure& state_changed_cb,
29 const HighLevelBufferCB& high_level_buffer_cb)
30 : config_(config),
31 state_changed_cb_(state_changed_cb),
32 high_level_buffer_cb_(high_level_buffer_cb),
33 state_(kLowLevel),
34 media_time_(::media::kNoTimestamp()),
35 max_rendering_time_(::media::kNoTimestamp()),
36 buffered_time_(::media::kNoTimestamp()) {
37 }
38
39 BufferingState::~BufferingState() {
40 }
41
42 void BufferingState::OnConfigChanged() {
43 state_ = GetBufferLevelState();
44 }
45
46 void BufferingState::SetMediaTime(base::TimeDelta media_time) {
47 media_time_ = media_time;
48 switch (state_) {
49 case kLowLevel:
50 case kMediumLevel:
51 case kHighLevel:
52 UpdateState(GetBufferLevelState());
53 break;
54 case kEosReached:
55 break;
56 }
57 }
58
59 void BufferingState::SetMaxRenderingTime(base::TimeDelta max_rendering_time) {
60 max_rendering_time_ = max_rendering_time;
61 }
62
63 base::TimeDelta BufferingState::GetMaxRenderingTime() const {
64 return max_rendering_time_;
65 }
66
67 void BufferingState::SetBufferedTime(base::TimeDelta buffered_time) {
68 buffered_time_ = buffered_time;
69 switch (state_) {
70 case kLowLevel:
71 case kMediumLevel:
72 case kHighLevel:
73 UpdateState(GetBufferLevelState());
74 break;
75 case kEosReached:
76 break;
77 }
78 }
79
80 void BufferingState::NotifyEos() {
81 UpdateState(kEosReached);
82 }
83
84 void BufferingState::NotifyMaxCapacity(base::TimeDelta buffered_time) {
85 if (media_time_ == ::media::kNoTimestamp() ||
86 buffered_time == ::media::kNoTimestamp()) {
87 LOG(WARNING) << "Max capacity with no timestamp";
88 return;
89 }
90 base::TimeDelta buffer_duration = buffered_time - media_time_;
91 if (buffer_duration < config_->high_level())
92 high_level_buffer_cb_.Run(buffer_duration);
93 }
94
95 std::string BufferingState::ToString() const {
96 std::ostringstream s;
97 s << "state=" << state_
98 << " media_time_ms=" << media_time_.InMilliseconds()
99 << " buffered_time_ms=" << buffered_time_.InMilliseconds()
100 << " low_level_ms=" << config_->low_level().InMilliseconds()
101 << " high_level_ms=" << config_->high_level().InMilliseconds();
102 return s.str();
103 }
104
105 BufferingState::State BufferingState::GetBufferLevelState() const {
106 if (media_time_ == ::media::kNoTimestamp() ||
107 buffered_time_ == ::media::kNoTimestamp()) {
108 return kLowLevel;
109 }
110
111 base::TimeDelta buffer_duration = buffered_time_ - media_time_;
112 if (buffer_duration < config_->low_level())
113 return kLowLevel;
114 if (buffer_duration >= config_->high_level())
115 return kHighLevel;
116 return kMediumLevel;
117 }
118
119 void BufferingState::UpdateState(State new_state) {
120 if (new_state == state_)
121 return;
122
123 state_ = new_state;
124 if (!state_changed_cb_.is_null())
125 state_changed_cb_.Run();
126 }
127
128 } // namespace media
129 } // namespace chromecast
OLDNEW
« no previous file with comments | « chromecast/media/cma/base/buffering_state.h ('k') | chromecast/media/cma/base/cma_logging.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698