OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 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_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ | 5 #ifndef CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ |
6 #define CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ | 6 #define CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ |
7 | 7 |
8 #include <vector> | 8 #include <vector> |
9 | 9 |
10 #include "base/basictypes.h" | 10 #include "base/basictypes.h" |
11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
12 #include "base/memory/scoped_ptr.h" | 12 #include "base/memory/scoped_ptr.h" |
13 #include "cc/input/layer_scroll_offset_delegate.h" | 13 #include "cc/input/layer_scroll_offset_delegate.h" |
14 #include "content/browser/android/in_process/synchronous_compositor_output_surfa
ce.h" | 14 #include "content/browser/android/in_process/synchronous_compositor_output_surfa
ce.h" |
15 #include "content/common/input/input_event_ack_state.h" | 15 #include "content/common/input/input_event_ack_state.h" |
16 #include "content/public/browser/android/synchronous_compositor.h" | 16 #include "content/public/browser/android/synchronous_compositor.h" |
17 #include "content/public/browser/web_contents_user_data.h" | 17 #include "content/public/browser/web_contents_user_data.h" |
18 #include "ipc/ipc_message.h" | 18 #include "ipc/ipc_message.h" |
19 | 19 |
20 namespace cc { | 20 namespace cc { |
21 class BeginFrameSource; | 21 struct BeginFrameArgs; |
22 class InputHandler; | 22 class InputHandler; |
23 } | 23 } |
24 | 24 |
25 namespace blink { | 25 namespace blink { |
26 class WebInputEvent; | 26 class WebInputEvent; |
27 } | 27 } |
28 | 28 |
29 namespace content { | 29 namespace content { |
30 class InputHandlerManager; | 30 class InputHandlerManager; |
31 class SynchronousCompositorExternalBeginFrameSource; | 31 class SynchronousCompositorExternalBeginFrameSource; |
(...skipping 17 matching lines...) Expand all Loading... |
49 | 49 |
50 InputEventAckState HandleInputEvent(const blink::WebInputEvent& input_event); | 50 InputEventAckState HandleInputEvent(const blink::WebInputEvent& input_event); |
51 | 51 |
52 // Called by SynchronousCompositorRegistry. | 52 // Called by SynchronousCompositorRegistry. |
53 void DidInitializeRendererObjects( | 53 void DidInitializeRendererObjects( |
54 SynchronousCompositorOutputSurface* output_surface, | 54 SynchronousCompositorOutputSurface* output_surface, |
55 SynchronousCompositorExternalBeginFrameSource* begin_frame_source); | 55 SynchronousCompositorExternalBeginFrameSource* begin_frame_source); |
56 void DidDestroyRendererObjects(); | 56 void DidDestroyRendererObjects(); |
57 | 57 |
58 // Called by SynchronousCompositorExternalBeginFrameSource. | 58 // Called by SynchronousCompositorExternalBeginFrameSource. |
59 void NeedsBeginFramesChanged() const; | 59 void OnNeedsBeginFramesChange(bool needs_begin_frames); |
| 60 |
| 61 // Called by SynchronousCompositorOutputSurface. |
| 62 void PostInvalidate(); |
| 63 |
| 64 // Called by RenderWidgetHostViewAndroid. |
| 65 void BeginFrame(const cc::BeginFrameArgs& args); |
60 | 66 |
61 // SynchronousCompositor | 67 // SynchronousCompositor |
62 bool InitializeHwDraw() override; | 68 bool InitializeHwDraw() override; |
63 void ReleaseHwDraw() override; | 69 void ReleaseHwDraw() override; |
64 scoped_ptr<cc::CompositorFrame> DemandDrawHw( | 70 scoped_ptr<cc::CompositorFrame> DemandDrawHw( |
65 gfx::Size surface_size, | 71 gfx::Size surface_size, |
66 const gfx::Transform& transform, | 72 const gfx::Transform& transform, |
67 gfx::Rect viewport, | 73 gfx::Rect viewport, |
68 gfx::Rect clip, | 74 gfx::Rect clip, |
69 gfx::Rect viewport_rect_for_tile_priority, | 75 gfx::Rect viewport_rect_for_tile_priority, |
70 const gfx::Transform& transform_for_tile_priority) override; | 76 const gfx::Transform& transform_for_tile_priority) override; |
71 bool DemandDrawSw(SkCanvas* canvas) override; | 77 bool DemandDrawSw(SkCanvas* canvas) override; |
72 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; | 78 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; |
73 void SetMemoryPolicy(size_t bytes_limit) override; | 79 void SetMemoryPolicy(size_t bytes_limit) override; |
74 void DidChangeRootLayerScrollOffset() override; | 80 void DidChangeRootLayerScrollOffset() override; |
| 81 void SetIsActive(bool is_active) override; |
75 | 82 |
76 // LayerScrollOffsetDelegate | 83 // LayerScrollOffsetDelegate |
77 gfx::ScrollOffset GetTotalScrollOffset() override; | 84 gfx::ScrollOffset GetTotalScrollOffset() override; |
78 void UpdateRootLayerState(const gfx::ScrollOffset& total_scroll_offset, | 85 void UpdateRootLayerState(const gfx::ScrollOffset& total_scroll_offset, |
79 const gfx::ScrollOffset& max_scroll_offset, | 86 const gfx::ScrollOffset& max_scroll_offset, |
80 const gfx::SizeF& scrollable_size, | 87 const gfx::SizeF& scrollable_size, |
81 float page_scale_factor, | 88 float page_scale_factor, |
82 float min_page_scale_factor, | 89 float min_page_scale_factor, |
83 float max_page_scale_factor) override; | 90 float max_page_scale_factor) override; |
84 bool IsExternalFlingActive() const override; | 91 bool IsExternalFlingActive() const override; |
85 | 92 |
86 void SetInputHandler(cc::InputHandler* input_handler); | 93 void SetInputHandler(cc::InputHandler* input_handler); |
87 void DidOverscroll(const DidOverscrollParams& params); | 94 void DidOverscroll(const DidOverscrollParams& params); |
88 void DidStopFlinging(); | 95 void DidStopFlinging(); |
89 | 96 |
90 private: | 97 private: |
91 friend class WebContentsUserData<SynchronousCompositorImpl>; | 98 friend class WebContentsUserData<SynchronousCompositorImpl>; |
92 friend class SynchronousCompositor; | 99 friend class SynchronousCompositor; |
93 explicit SynchronousCompositorImpl(WebContents* contents); | 100 explicit SynchronousCompositorImpl(WebContents* contents); |
94 ~SynchronousCompositorImpl() override; | 101 ~SynchronousCompositorImpl() override; |
95 | 102 |
96 void SetClient(SynchronousCompositorClient* compositor_client); | 103 void SetClient(SynchronousCompositorClient* compositor_client); |
97 void UpdateFrameMetaData(const cc::CompositorFrameMetadata& frame_info); | 104 void UpdateFrameMetaData(const cc::CompositorFrameMetadata& frame_info); |
98 void NotifyDidDestroyCompositorToClient(); | 105 void NotifyDidDestroyCompositorToClient(); |
99 void DidActivatePendingTree(); | 106 void DidActivatePendingTree(); |
100 void DeliverMessages(); | 107 void DeliverMessages(); |
101 bool CalledOnValidThread() const; | 108 bool CalledOnValidThread() const; |
| 109 void UpdateNeedsBeginFrames(); |
102 | 110 |
103 SynchronousCompositorClient* compositor_client_; | 111 SynchronousCompositorClient* compositor_client_; |
104 SynchronousCompositorOutputSurface* output_surface_; | 112 SynchronousCompositorOutputSurface* output_surface_; |
105 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; | 113 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; |
106 WebContents* contents_; | 114 WebContents* contents_; |
107 const int routing_id_; | 115 const int routing_id_; |
108 cc::InputHandler* input_handler_; | 116 cc::InputHandler* input_handler_; |
109 bool invoking_composite_; | 117 bool is_active_; |
| 118 bool renderer_needs_begin_frames_; |
110 | 119 |
111 base::WeakPtrFactory<SynchronousCompositorImpl> weak_ptr_factory_; | 120 base::WeakPtrFactory<SynchronousCompositorImpl> weak_ptr_factory_; |
112 | 121 |
113 DISALLOW_COPY_AND_ASSIGN(SynchronousCompositorImpl); | 122 DISALLOW_COPY_AND_ASSIGN(SynchronousCompositorImpl); |
114 }; | 123 }; |
115 | 124 |
116 } // namespace content | 125 } // namespace content |
117 | 126 |
118 #endif // CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ | 127 #endif // CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ |
OLD | NEW |