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

Side by Side Diff: cc/surfaces/display_scheduler.cc

Issue 720333005: Add DisplayScheduler to enable BeginFrame-based scheduling of surfaces. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 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 | « cc/surfaces/display_scheduler.h ('k') | cc/surfaces/onscreen_display_client.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 "cc/surfaces/display_scheduler.h"
6
7 #include "base/trace_event/trace_event.h"
8 #include "cc/output/output_surface.h"
9 #include "ui/gfx/frame_time.h"
10
11 namespace cc {
12
13 DisplayScheduler::DisplayScheduler(
14 OutputSurface* output_surface,
15 Display* display,
16 scoped_refptr<base::SingleThreadTaskRunner> task_runner)
17 : output_surface_(output_surface),
18 display_(display),
19 task_runner_(task_runner),
20 output_surface_lost_(false),
21 need_draw_(false),
22 pending_frames_(0),
23 weak_ptr_factory_(this) {
24 begin_frame_source_ = SyntheticBeginFrameSource::Create(
25 task_runner_.get(), gfx::FrameTime::Now(),
26 BeginFrameArgs::DefaultInterval());
27 begin_frame_source_->AddObserver(this);
28 }
29
30 DisplayScheduler::~DisplayScheduler() {
31 }
32
33 void DisplayScheduler::CommitVSyncParameters(base::TimeTicks timebase,
34 base::TimeDelta interval) {
35 if (begin_frame_source_ && interval != base::TimeDelta())
36 begin_frame_source_->OnUpdateVSyncParameters(timebase, interval);
37 }
38
39 void DisplayScheduler::DisplayDamaged() {
40 TRACE_EVENT0("cc", "DisplayScheduler::DisplayDamaged");
41 begin_frame_source_->SetNeedsBeginFrames(!output_surface_lost_);
42 need_draw_ = true;
43 }
44
45 void DisplayScheduler::OutputSurfaceLost() {
46 output_surface_lost_ = true;
47 begin_frame_source_->SetNeedsBeginFrames(false);
48 }
49
50 void DisplayScheduler::Draw() {
51 TRACE_EVENT0("cc", "DisplayScheduler::Draw");
52 if (!need_draw_) {
53 begin_frame_source_->SetNeedsBeginFrames(false);
54 return;
55 }
56 if (pending_frames_ >= display_->GetMaxFramesPending())
57 return;
58 if (output_surface_lost_)
59 return;
60 need_draw_ = false;
61 base::TimeTicks start_time = gfx::FrameTime::Now();
62 display_->Draw();
63 }
64
65 void DisplayScheduler::OnBeginFrame(const BeginFrameArgs& args) {
66 TRACE_EVENT0("cc", "DisplayScheduler::OnBeginFrame");
67 current_begin_frame_args_ = args;
68 // TODO(jbauman): Use deadline to schedule draw.
69 task_runner_->PostTask(FROM_HERE, base::Bind(&DisplayScheduler::Draw,
70 weak_ptr_factory_.GetWeakPtr()));
71 }
72
73 const BeginFrameArgs DisplayScheduler::LastUsedBeginFrameArgs() const {
74 return current_begin_frame_args_;
75 }
76
77 void DisplayScheduler::AsValueInto(base::trace_event::TracedValue* dict) const {
78 }
79
80 void DisplayScheduler::DidSwapBuffers() {
81 pending_frames_++;
82 }
83
84 void DisplayScheduler::DidSwapBuffersComplete() {
85 pending_frames_--;
86 }
87
88 } // namespace cc
OLDNEW
« no previous file with comments | « cc/surfaces/display_scheduler.h ('k') | cc/surfaces/onscreen_display_client.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698