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 #ifndef CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ |
6 #define CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ |
7 | 7 |
8 #include <memory> | 8 #include <memory> |
9 | 9 |
10 #include "base/macros.h" | 10 #include "base/macros.h" |
11 #include "cc/scheduler/begin_frame_source.h" | 11 #include "cc/scheduler/begin_frame_source.h" |
12 #include "content/browser/renderer_host/delegated_frame_host.h" | 12 #include "content/browser/renderer_host/delegated_frame_host.h" |
13 #include "ui/compositor/compositor.h" | 13 #include "ui/compositor/compositor.h" |
14 #include "ui/compositor/compositor_observer.h" | 14 #include "ui/compositor/compositor_observer.h" |
15 | 15 |
16 namespace ui { | 16 namespace ui { |
17 class AcceleratedWidgetMac; | 17 class AcceleratedWidgetMac; |
18 class AcceleratedWidgetMacNSView; | 18 class AcceleratedWidgetMacNSView; |
19 } | 19 } |
20 | 20 |
21 namespace content { | 21 namespace content { |
22 | 22 |
23 class RecyclableCompositorMac; | 23 class RecyclableCompositorMac; |
24 | 24 |
25 class BrowserCompositorMacClient { | 25 class BrowserCompositorMacClient { |
26 public: | 26 public: |
27 virtual NSView* BrowserCompositorMacGetNSView() const = 0; | 27 virtual NSView* BrowserCompositorMacGetNSView() const = 0; |
28 virtual SkColor BrowserCompositorMacGetGutterColor(SkColor color) const = 0; | 28 virtual SkColor BrowserCompositorMacGetGutterColor(SkColor color) const = 0; |
29 virtual void BrowserCompositorMacSendCompositorSwapAck( | |
30 int output_surface_id, | |
31 const cc::CompositorFrameAck& ack) = 0; | |
32 virtual void BrowserCompositorMacSendReclaimCompositorResources( | 29 virtual void BrowserCompositorMacSendReclaimCompositorResources( |
33 int output_surface_id, | 30 int output_surface_id, |
34 const cc::CompositorFrameAck& ack) = 0; | 31 bool is_swap_ack, |
| 32 const cc::ReturnedResourceArray& resources) = 0; |
35 virtual void BrowserCompositorMacOnLostCompositorResources() = 0; | 33 virtual void BrowserCompositorMacOnLostCompositorResources() = 0; |
36 virtual void BrowserCompositorMacUpdateVSyncParameters( | 34 virtual void BrowserCompositorMacUpdateVSyncParameters( |
37 const base::TimeTicks& timebase, | 35 const base::TimeTicks& timebase, |
38 const base::TimeDelta& interval) = 0; | 36 const base::TimeDelta& interval) = 0; |
39 virtual void BrowserCompositorMacSendBeginFrame( | 37 virtual void BrowserCompositorMacSendBeginFrame( |
40 const cc::BeginFrameArgs& args) = 0; | 38 const cc::BeginFrameArgs& args) = 0; |
41 }; | 39 }; |
42 | 40 |
43 // This class owns a DelegatedFrameHost, and will dynamically attach and | 41 // This class owns a DelegatedFrameHost, and will dynamically attach and |
44 // detach it from a ui::Compositor as needed. The ui::Compositor will be | 42 // detach it from a ui::Compositor as needed. The ui::Compositor will be |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 | 102 |
105 // DelegatedFrameHostClient implementation. | 103 // DelegatedFrameHostClient implementation. |
106 ui::Layer* DelegatedFrameHostGetLayer() const override; | 104 ui::Layer* DelegatedFrameHostGetLayer() const override; |
107 bool DelegatedFrameHostIsVisible() const override; | 105 bool DelegatedFrameHostIsVisible() const override; |
108 SkColor DelegatedFrameHostGetGutterColor(SkColor color) const override; | 106 SkColor DelegatedFrameHostGetGutterColor(SkColor color) const override; |
109 gfx::Size DelegatedFrameHostDesiredSizeInDIP() const override; | 107 gfx::Size DelegatedFrameHostDesiredSizeInDIP() const override; |
110 bool DelegatedFrameCanCreateResizeLock() const override; | 108 bool DelegatedFrameCanCreateResizeLock() const override; |
111 std::unique_ptr<ResizeLock> DelegatedFrameHostCreateResizeLock( | 109 std::unique_ptr<ResizeLock> DelegatedFrameHostCreateResizeLock( |
112 bool defer_compositor_lock) override; | 110 bool defer_compositor_lock) override; |
113 void DelegatedFrameHostResizeLockWasReleased() override; | 111 void DelegatedFrameHostResizeLockWasReleased() override; |
114 void DelegatedFrameHostSendCompositorSwapAck( | |
115 int output_surface_id, | |
116 const cc::CompositorFrameAck& ack) override; | |
117 void DelegatedFrameHostSendReclaimCompositorResources( | 112 void DelegatedFrameHostSendReclaimCompositorResources( |
118 int output_surface_id, | 113 int output_surface_id, |
119 const cc::CompositorFrameAck& ack) override; | 114 bool is_swap_ack, |
| 115 const cc::ReturnedResourceArray& resources) override; |
120 void DelegatedFrameHostOnLostCompositorResources() override; | 116 void DelegatedFrameHostOnLostCompositorResources() override; |
121 void DelegatedFrameHostUpdateVSyncParameters( | 117 void DelegatedFrameHostUpdateVSyncParameters( |
122 const base::TimeTicks& timebase, | 118 const base::TimeTicks& timebase, |
123 const base::TimeDelta& interval) override; | 119 const base::TimeDelta& interval) override; |
124 void SetBeginFrameSource(cc::BeginFrameSource* source) override; | 120 void SetBeginFrameSource(cc::BeginFrameSource* source) override; |
125 bool IsAutoResizeEnabled() const override; | 121 bool IsAutoResizeEnabled() const override; |
126 | 122 |
127 // cc::BeginFrameObserver implementation. | 123 // cc::BeginFrameObserver implementation. |
128 void OnBeginFrame(const cc::BeginFrameArgs& args) override; | 124 void OnBeginFrame(const cc::BeginFrameArgs& args) override; |
129 const cc::BeginFrameArgs& LastUsedBeginFrameArgs() const override; | 125 const cc::BeginFrameArgs& LastUsedBeginFrameArgs() const override; |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
192 cc::BeginFrameSource* begin_frame_source_ = nullptr; | 188 cc::BeginFrameSource* begin_frame_source_ = nullptr; |
193 cc::BeginFrameArgs last_begin_frame_args_; | 189 cc::BeginFrameArgs last_begin_frame_args_; |
194 bool needs_begin_frames_ = false; | 190 bool needs_begin_frames_ = false; |
195 | 191 |
196 base::WeakPtrFactory<BrowserCompositorMac> weak_factory_; | 192 base::WeakPtrFactory<BrowserCompositorMac> weak_factory_; |
197 }; | 193 }; |
198 | 194 |
199 } // namespace content | 195 } // namespace content |
200 | 196 |
201 #endif // CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ | 197 #endif // CONTENT_BROWSER_RENDERER_HOST_BROWSER_COMPOSITOR_VIEW_MAC_H_ |
OLD | NEW |