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" |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after 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 void DidActivatePendingTree(); | |
boliu
2015/03/20 18:59:06
This can stay private
sunnyps
2015/03/20 22:48:40
Done.
| |
60 | 64 |
61 // SynchronousCompositor | 65 // SynchronousCompositor |
62 bool InitializeHwDraw() override; | 66 bool InitializeHwDraw() override; |
63 void ReleaseHwDraw() override; | 67 void ReleaseHwDraw() override; |
64 scoped_ptr<cc::CompositorFrame> DemandDrawHw( | 68 scoped_ptr<cc::CompositorFrame> DemandDrawHw( |
65 gfx::Size surface_size, | 69 gfx::Size surface_size, |
66 const gfx::Transform& transform, | 70 const gfx::Transform& transform, |
67 gfx::Rect viewport, | 71 gfx::Rect viewport, |
68 gfx::Rect clip, | 72 gfx::Rect clip, |
69 gfx::Rect viewport_rect_for_tile_priority, | 73 gfx::Rect viewport_rect_for_tile_priority, |
70 const gfx::Transform& transform_for_tile_priority) override; | 74 const gfx::Transform& transform_for_tile_priority) override; |
71 bool DemandDrawSw(SkCanvas* canvas) override; | 75 bool DemandDrawSw(SkCanvas* canvas) override; |
72 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; | 76 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; |
73 void SetMemoryPolicy(size_t bytes_limit) override; | 77 void SetMemoryPolicy(size_t bytes_limit) override; |
74 void DidChangeRootLayerScrollOffset() override; | 78 void DidChangeRootLayerScrollOffset() override; |
79 void SetIsActive(bool is_active) override; | |
80 void SendBeginFrame(const cc::BeginFrameArgs& args) override; | |
75 | 81 |
76 // LayerScrollOffsetDelegate | 82 // LayerScrollOffsetDelegate |
77 gfx::ScrollOffset GetTotalScrollOffset() override; | 83 gfx::ScrollOffset GetTotalScrollOffset() override; |
78 void UpdateRootLayerState(const gfx::ScrollOffset& total_scroll_offset, | 84 void UpdateRootLayerState(const gfx::ScrollOffset& total_scroll_offset, |
79 const gfx::ScrollOffset& max_scroll_offset, | 85 const gfx::ScrollOffset& max_scroll_offset, |
80 const gfx::SizeF& scrollable_size, | 86 const gfx::SizeF& scrollable_size, |
81 float page_scale_factor, | 87 float page_scale_factor, |
82 float min_page_scale_factor, | 88 float min_page_scale_factor, |
83 float max_page_scale_factor) override; | 89 float max_page_scale_factor) override; |
84 bool IsExternalFlingActive() const override; | 90 bool IsExternalFlingActive() const override; |
85 | 91 |
86 void SetInputHandler(cc::InputHandler* input_handler); | 92 void SetInputHandler(cc::InputHandler* input_handler); |
87 void DidOverscroll(const DidOverscrollParams& params); | 93 void DidOverscroll(const DidOverscrollParams& params); |
88 void DidStopFlinging(); | 94 void DidStopFlinging(); |
89 | 95 |
90 private: | 96 private: |
91 friend class WebContentsUserData<SynchronousCompositorImpl>; | 97 friend class WebContentsUserData<SynchronousCompositorImpl>; |
92 friend class SynchronousCompositor; | 98 friend class SynchronousCompositor; |
93 explicit SynchronousCompositorImpl(WebContents* contents); | 99 explicit SynchronousCompositorImpl(WebContents* contents); |
94 ~SynchronousCompositorImpl() override; | 100 ~SynchronousCompositorImpl() override; |
95 | 101 |
96 void SetClient(SynchronousCompositorClient* compositor_client); | 102 void SetClient(SynchronousCompositorClient* compositor_client); |
97 void UpdateFrameMetaData(const cc::CompositorFrameMetadata& frame_info); | 103 void UpdateFrameMetaData(const cc::CompositorFrameMetadata& frame_info); |
98 void NotifyDidDestroyCompositorToClient(); | 104 void NotifyDidDestroyCompositorToClient(); |
99 void DidActivatePendingTree(); | |
100 void DeliverMessages(); | 105 void DeliverMessages(); |
101 bool CalledOnValidThread() const; | 106 bool CalledOnValidThread() const; |
107 void UpdateNeedsBeginFrames(); | |
102 | 108 |
103 SynchronousCompositorClient* compositor_client_; | 109 SynchronousCompositorClient* compositor_client_; |
104 SynchronousCompositorOutputSurface* output_surface_; | 110 SynchronousCompositorOutputSurface* output_surface_; |
105 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; | 111 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; |
106 WebContents* contents_; | 112 WebContents* contents_; |
107 const int routing_id_; | 113 const int routing_id_; |
108 cc::InputHandler* input_handler_; | 114 cc::InputHandler* input_handler_; |
109 bool invoking_composite_; | 115 bool invoking_composite_; |
116 bool is_active_; | |
117 bool renderer_needs_begin_frames_; | |
110 | 118 |
111 base::WeakPtrFactory<SynchronousCompositorImpl> weak_ptr_factory_; | 119 base::WeakPtrFactory<SynchronousCompositorImpl> weak_ptr_factory_; |
112 | 120 |
113 DISALLOW_COPY_AND_ASSIGN(SynchronousCompositorImpl); | 121 DISALLOW_COPY_AND_ASSIGN(SynchronousCompositorImpl); |
114 }; | 122 }; |
115 | 123 |
116 } // namespace content | 124 } // namespace content |
117 | 125 |
118 #endif // CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ | 126 #endif // CONTENT_BROWSER_ANDROID_IN_PROCESS_SYNCHRONOUS_COMPOSITOR_IMPL_H_ |
OLD | NEW |