OLD | NEW |
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2013 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 CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ | 5 #ifndef CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ |
6 #define CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ | 6 #define CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ |
7 | 7 |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/memory/weak_ptr.h" | 9 #include "base/memory/weak_ptr.h" |
10 #include "base/time/time.h" | 10 #include "base/time/time.h" |
(...skipping 26 matching lines...) Expand all Loading... |
37 public cc::LayerTreeHostSingleThreadClient { | 37 public cc::LayerTreeHostSingleThreadClient { |
38 public: | 38 public: |
39 // Attempt to construct and initialize a compositor instance for the widget | 39 // Attempt to construct and initialize a compositor instance for the widget |
40 // with the given settings. Returns NULL if initialization fails. | 40 // with the given settings. Returns NULL if initialization fails. |
41 static scoped_ptr<RenderWidgetCompositor> Create(RenderWidget* widget, | 41 static scoped_ptr<RenderWidgetCompositor> Create(RenderWidget* widget, |
42 bool threaded); | 42 bool threaded); |
43 | 43 |
44 virtual ~RenderWidgetCompositor(); | 44 virtual ~RenderWidgetCompositor(); |
45 | 45 |
46 const base::WeakPtr<cc::InputHandler>& GetInputHandler(); | 46 const base::WeakPtr<cc::InputHandler>& GetInputHandler(); |
| 47 void SetSuppressScheduleComposite(bool suppress); |
47 bool BeginMainFrameRequested() const; | 48 bool BeginMainFrameRequested() const; |
| 49 void UpdateAnimations(base::TimeTicks time); |
48 void SetNeedsDisplayOnAllLayers(); | 50 void SetNeedsDisplayOnAllLayers(); |
49 void SetRasterizeOnlyVisibleContent(); | 51 void SetRasterizeOnlyVisibleContent(); |
50 void UpdateTopControlsState(cc::TopControlsState constraints, | 52 void UpdateTopControlsState(cc::TopControlsState constraints, |
51 cc::TopControlsState current, | 53 cc::TopControlsState current, |
52 bool animate); | 54 bool animate); |
53 void SetOverdrawBottomHeight(float overdraw_bottom_height); | 55 void SetOverdrawBottomHeight(float overdraw_bottom_height); |
54 void SetNeedsRedrawRect(gfx::Rect damage_rect); | 56 void SetNeedsRedrawRect(gfx::Rect damage_rect); |
55 // Like setNeedsRedraw but forces the frame to be drawn, without early-outs. | 57 // Like setNeedsRedraw but forces the frame to be drawn, without early-outs. |
56 // Redraw will be forced after the next commit | 58 // Redraw will be forced after the next commit |
57 void SetNeedsForcedRedraw(); | 59 void SetNeedsForcedRedraw(); |
(...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
134 virtual scoped_ptr<cc::OutputSurface> CreateOutputSurface(bool fallback) | 136 virtual scoped_ptr<cc::OutputSurface> CreateOutputSurface(bool fallback) |
135 OVERRIDE; | 137 OVERRIDE; |
136 virtual void DidInitializeOutputSurface() OVERRIDE; | 138 virtual void DidInitializeOutputSurface() OVERRIDE; |
137 virtual void WillCommit() OVERRIDE; | 139 virtual void WillCommit() OVERRIDE; |
138 virtual void DidCommit() OVERRIDE; | 140 virtual void DidCommit() OVERRIDE; |
139 virtual void DidCommitAndDrawFrame() OVERRIDE; | 141 virtual void DidCommitAndDrawFrame() OVERRIDE; |
140 virtual void DidCompleteSwapBuffers() OVERRIDE; | 142 virtual void DidCompleteSwapBuffers() OVERRIDE; |
141 virtual void RateLimitSharedMainThreadContext() OVERRIDE; | 143 virtual void RateLimitSharedMainThreadContext() OVERRIDE; |
142 | 144 |
143 // cc::LayerTreeHostSingleThreadClient implementation. | 145 // cc::LayerTreeHostSingleThreadClient implementation. |
| 146 virtual void ScheduleComposite() OVERRIDE; |
144 virtual void ScheduleAnimation() OVERRIDE; | 147 virtual void ScheduleAnimation() OVERRIDE; |
145 virtual void DidPostSwapBuffers() OVERRIDE; | 148 virtual void DidPostSwapBuffers() OVERRIDE; |
146 virtual void DidAbortSwapBuffers() OVERRIDE; | 149 virtual void DidAbortSwapBuffers() OVERRIDE; |
147 | 150 |
148 private: | 151 private: |
149 RenderWidgetCompositor(RenderWidget* widget, bool threaded); | 152 RenderWidgetCompositor(RenderWidget* widget, bool threaded); |
150 | 153 |
151 void Initialize(cc::LayerTreeSettings settings); | 154 void Initialize(cc::LayerTreeSettings settings); |
152 | 155 |
153 bool threaded_; | 156 bool threaded_; |
| 157 bool suppress_schedule_composite_; |
154 RenderWidget* widget_; | 158 RenderWidget* widget_; |
155 scoped_ptr<cc::LayerTreeHost> layer_tree_host_; | 159 scoped_ptr<cc::LayerTreeHost> layer_tree_host_; |
156 }; | 160 }; |
157 | 161 |
158 } // namespace content | 162 } // namespace content |
159 | 163 |
160 #endif // CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ | 164 #endif // CONTENT_RENDERER_GPU_RENDER_WIDGET_COMPOSITOR_H_ |
OLD | NEW |