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

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

Issue 1887243002: cc: Remove retro frames from scheduler. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 8 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 #ifndef CC_SURFACES_DISPLAY_SCHEDULER_H_ 5 #ifndef CC_SURFACES_DISPLAY_SCHEDULER_H_
6 #define CC_SURFACES_DISPLAY_SCHEDULER_H_ 6 #define CC_SURFACES_DISPLAY_SCHEDULER_H_
7 7
8 #include <memory> 8 #include <memory>
9 9
10 #include "base/cancelable_callback.h" 10 #include "base/cancelable_callback.h"
11 #include "base/macros.h" 11 #include "base/macros.h"
12 #include "base/memory/ref_counted.h" 12 #include "base/memory/ref_counted.h"
13 #include "base/single_thread_task_runner.h" 13 #include "base/single_thread_task_runner.h"
14 #include "cc/scheduler/begin_frame_source.h" 14 #include "cc/scheduler/begin_frame_source.h"
15 #include "cc/surfaces/surface_id.h" 15 #include "cc/surfaces/surface_id.h"
16 #include "cc/surfaces/surfaces_export.h" 16 #include "cc/surfaces/surfaces_export.h"
17 17
18 namespace cc { 18 namespace cc {
19 19
20 class OutputSurface; 20 class OutputSurface;
21 class BeginFrameSource; 21 class BeginFrameSource;
22 22
23 class CC_SURFACES_EXPORT DisplaySchedulerClient { 23 class CC_SURFACES_EXPORT DisplaySchedulerClient {
24 public: 24 public:
25 virtual ~DisplaySchedulerClient() {} 25 virtual ~DisplaySchedulerClient() {}
26 26
27 virtual bool DrawAndSwap() = 0; 27 virtual bool DrawAndSwap() = 0;
28 }; 28 };
29 29
30 class CC_SURFACES_EXPORT DisplayScheduler : public BeginFrameObserverBase { 30 class CC_SURFACES_EXPORT DisplayScheduler : public BeginFrameObserver {
31 public: 31 public:
32 DisplayScheduler(DisplaySchedulerClient* client, 32 DisplayScheduler(DisplaySchedulerClient* client,
33 BeginFrameSource* begin_frame_source, 33 BeginFrameSource* begin_frame_source,
34 base::SingleThreadTaskRunner* task_runner, 34 base::SingleThreadTaskRunner* task_runner,
35 int max_pending_swaps); 35 int max_pending_swaps);
36 ~DisplayScheduler() override; 36 ~DisplayScheduler() override;
37 37
38 void SetRootSurfaceResourcesLocked(bool locked); 38 void SetRootSurfaceResourcesLocked(bool locked);
39 void ForceImmediateSwapIfPossible(); 39 void ForceImmediateSwapIfPossible();
40 virtual void DisplayResized(); 40 virtual void DisplayResized();
41 virtual void SetNewRootSurface(SurfaceId root_surface_id); 41 virtual void SetNewRootSurface(SurfaceId root_surface_id);
42 virtual void SurfaceDamaged(SurfaceId surface_id); 42 virtual void SurfaceDamaged(SurfaceId surface_id);
43 43
44 virtual void DidSwapBuffers(); 44 virtual void DidSwapBuffers();
45 void DidSwapBuffersComplete(); 45 void DidSwapBuffersComplete();
46 46
47 void OutputSurfaceLost(); 47 void OutputSurfaceLost();
48 48
49 // BeginFrameObserverBase implementation 49 // BeginFrameObserver implementation
50 bool OnBeginFrameDerivedImpl(const BeginFrameArgs& args) override; 50 const BeginFrameArgs& LastUsedBeginFrameArgs() const override;
51 void OnBeginFrame(const BeginFrameArgs& args) override;
51 void OnBeginFrameSourcePausedChanged(bool paused) override; 52 void OnBeginFrameSourcePausedChanged(bool paused) override;
52 53
54 // TODO(brianderson): Add tracing support.
55 void AsValueInto(base::trace_event::TracedValue* dict) const override {}
56
53 BeginFrameSource* begin_frame_source_for_children() { 57 BeginFrameSource* begin_frame_source_for_children() {
54 return begin_frame_source_for_children_.get(); 58 return begin_frame_source_for_children_.get();
55 } 59 }
56 60
57 protected: 61 protected:
58 base::TimeTicks DesiredBeginFrameDeadlineTime(); 62 base::TimeTicks DesiredBeginFrameDeadlineTime();
59 virtual void ScheduleBeginFrameDeadline(); 63 virtual void ScheduleBeginFrameDeadline();
60 void AttemptDrawAndSwap(); 64 void AttemptDrawAndSwap();
61 void OnBeginFrameDeadline(); 65 void OnBeginFrameDeadline();
62 void DrawAndSwap(); 66 void DrawAndSwap();
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after
96 100
97 base::WeakPtrFactory<DisplayScheduler> weak_ptr_factory_; 101 base::WeakPtrFactory<DisplayScheduler> weak_ptr_factory_;
98 102
99 private: 103 private:
100 DISALLOW_COPY_AND_ASSIGN(DisplayScheduler); 104 DISALLOW_COPY_AND_ASSIGN(DisplayScheduler);
101 }; 105 };
102 106
103 } // namespace cc 107 } // namespace cc
104 108
105 #endif // CC_SURFACES_DISPLAY_SCHEDULER_H_ 109 #endif // CC_SURFACES_DISPLAY_SCHEDULER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698