Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 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 | 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 "cc/scheduler/begin_frame_source.h" | 5 #include "cc/scheduler/begin_frame_source.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/logging.h" | 9 #include "base/logging.h" |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| (...skipping 192 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 203 BeginFrameSourceBase::AsValueInto(dict); | 203 BeginFrameSourceBase::AsValueInto(dict); |
| 204 dict->SetBoolean("send_begin_frame_posted_", send_begin_frame_posted_); | 204 dict->SetBoolean("send_begin_frame_posted_", send_begin_frame_posted_); |
| 205 } | 205 } |
| 206 | 206 |
| 207 // SyntheticBeginFrameSource --------------------------------------------- | 207 // SyntheticBeginFrameSource --------------------------------------------- |
| 208 scoped_ptr<SyntheticBeginFrameSource> SyntheticBeginFrameSource::Create( | 208 scoped_ptr<SyntheticBeginFrameSource> SyntheticBeginFrameSource::Create( |
| 209 base::SingleThreadTaskRunner* task_runner, | 209 base::SingleThreadTaskRunner* task_runner, |
| 210 base::TimeDelta initial_vsync_interval) { | 210 base::TimeDelta initial_vsync_interval) { |
| 211 scoped_ptr<DelayBasedTimeSource> time_source = | 211 scoped_ptr<DelayBasedTimeSource> time_source = |
| 212 DelayBasedTimeSource::Create(initial_vsync_interval, task_runner); | 212 DelayBasedTimeSource::Create(initial_vsync_interval, task_runner); |
| 213 return make_scoped_ptr(new SyntheticBeginFrameSource(time_source.Pass())); | 213 return make_scoped_ptr( |
| 214 new SyntheticBeginFrameSource(task_runner, time_source.Pass())); | |
| 214 } | 215 } |
| 215 | 216 |
| 216 SyntheticBeginFrameSource::SyntheticBeginFrameSource( | 217 SyntheticBeginFrameSource::SyntheticBeginFrameSource( |
| 218 base::SingleThreadTaskRunner* task_runner, | |
| 217 scoped_ptr<DelayBasedTimeSource> time_source) | 219 scoped_ptr<DelayBasedTimeSource> time_source) |
| 218 : BeginFrameSourceBase(), time_source_(time_source.Pass()) { | 220 : BeginFrameSourceBase(), |
| 221 task_runner_(task_runner), | |
| 222 time_source_(time_source.Pass()), | |
| 223 weak_factory_(this) { | |
| 219 time_source_->SetActive(false); | 224 time_source_->SetActive(false); |
| 220 time_source_->SetClient(this); | 225 time_source_->SetClient(this); |
| 221 } | 226 } |
| 222 | 227 |
| 223 SyntheticBeginFrameSource::~SyntheticBeginFrameSource() { | 228 SyntheticBeginFrameSource::~SyntheticBeginFrameSource() { |
| 224 if (NeedsBeginFrames()) | 229 if (NeedsBeginFrames()) |
| 225 time_source_->SetActive(false); | 230 time_source_->SetActive(false); |
| 226 } | 231 } |
| 227 | 232 |
| 228 void SyntheticBeginFrameSource::OnUpdateVSyncParameters( | 233 void SyntheticBeginFrameSource::OnUpdateVSyncParameters( |
| 229 base::TimeTicks new_vsync_timebase, | 234 base::TimeTicks new_vsync_timebase, |
| 230 base::TimeDelta new_vsync_interval) { | 235 base::TimeDelta new_vsync_interval) { |
| 231 time_source_->SetTimebaseAndInterval(new_vsync_timebase, new_vsync_interval); | 236 time_source_->SetTimebaseAndInterval(new_vsync_timebase, new_vsync_interval); |
| 232 } | 237 } |
| 233 | 238 |
| 234 BeginFrameArgs SyntheticBeginFrameSource::CreateBeginFrameArgs( | 239 BeginFrameArgs SyntheticBeginFrameSource::CreateBeginFrameArgs( |
| 235 base::TimeTicks frame_time, | 240 base::TimeTicks frame_time, |
| 236 BeginFrameArgs::BeginFrameArgsType type) { | 241 BeginFrameArgs::BeginFrameArgsType type) { |
| 237 base::TimeTicks deadline = time_source_->NextTickTime(); | 242 base::TimeTicks deadline = time_source_->NextTickTime(); |
| 238 return BeginFrameArgs::Create(BEGINFRAME_FROM_HERE, frame_time, deadline, | 243 return BeginFrameArgs::Create(BEGINFRAME_FROM_HERE, frame_time, deadline, |
| 239 time_source_->Interval(), type); | 244 time_source_->Interval(), type); |
| 240 } | 245 } |
| 241 | 246 |
| 242 // TimeSourceClient support | 247 // DelayBasedTimeSourceClient support |
| 248 void SyntheticBeginFrameSource::OnMissedTick() { | |
|
mithro-old
2015/06/30 08:11:52
I feel like these callbacks should just take a tim
| |
| 249 CallOnBeginFrame(CreateBeginFrameArgs(time_source_->MissedTickTime(), | |
| 250 BeginFrameArgs::MISSED)); | |
| 251 } | |
| 252 | |
| 243 void SyntheticBeginFrameSource::OnTimerTick() { | 253 void SyntheticBeginFrameSource::OnTimerTick() { |
| 244 CallOnBeginFrame(CreateBeginFrameArgs(time_source_->LastTickTime(), | 254 CallOnBeginFrame(CreateBeginFrameArgs(time_source_->LastTickTime(), |
| 245 BeginFrameArgs::NORMAL)); | 255 BeginFrameArgs::NORMAL)); |
| 246 } | 256 } |
| 247 | 257 |
| 248 // BeginFrameSourceBase support | 258 // BeginFrameSourceBase support |
| 249 void SyntheticBeginFrameSource::OnNeedsBeginFramesChange( | 259 void SyntheticBeginFrameSource::OnNeedsBeginFramesChange( |
| 250 bool needs_begin_frames) { | 260 bool needs_begin_frames) { |
| 251 base::TimeTicks missed_tick_time = | 261 time_source_->SetActive(needs_begin_frames); |
| 252 time_source_->SetActive(needs_begin_frames); | |
| 253 if (!missed_tick_time.is_null()) { | |
| 254 CallOnBeginFrame( | |
| 255 CreateBeginFrameArgs(missed_tick_time, BeginFrameArgs::MISSED)); | |
| 256 } | |
| 257 } | 262 } |
| 258 | 263 |
| 259 // Tracing support | 264 // Tracing support |
| 260 void SyntheticBeginFrameSource::AsValueInto( | 265 void SyntheticBeginFrameSource::AsValueInto( |
| 261 base::trace_event::TracedValue* dict) const { | 266 base::trace_event::TracedValue* dict) const { |
| 262 dict->SetString("type", "SyntheticBeginFrameSource"); | 267 dict->SetString("type", "SyntheticBeginFrameSource"); |
| 263 BeginFrameSourceBase::AsValueInto(dict); | 268 BeginFrameSourceBase::AsValueInto(dict); |
| 264 | 269 |
| 265 dict->BeginDictionary("time_source"); | 270 dict->BeginDictionary("time_source"); |
| 266 time_source_->AsValueInto(dict); | 271 time_source_->AsValueInto(dict); |
| (...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 460 if (!observer_->LastUsedBeginFrameArgs().IsValid()) | 465 if (!observer_->LastUsedBeginFrameArgs().IsValid()) |
| 461 return true; | 466 return true; |
| 462 | 467 |
| 463 // Only allow new args have a *strictly bigger* frame_time value and statisfy | 468 // Only allow new args have a *strictly bigger* frame_time value and statisfy |
| 464 // minimum interval requirement. | 469 // minimum interval requirement. |
| 465 return (args.frame_time >= | 470 return (args.frame_time >= |
| 466 observer_->LastUsedBeginFrameArgs().frame_time + minimum_interval_); | 471 observer_->LastUsedBeginFrameArgs().frame_time + minimum_interval_); |
| 467 } | 472 } |
| 468 | 473 |
| 469 } // namespace cc | 474 } // namespace cc |
| OLD | NEW |