| 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 SendBeginFrameOnDraw(); |
| 64 void DidActivatePendingTree(); |
| 60 | 65 |
| 61 // SynchronousCompositor | 66 // SynchronousCompositor |
| 62 bool InitializeHwDraw() override; | 67 bool InitializeHwDraw() override; |
| 63 void ReleaseHwDraw() override; | 68 void ReleaseHwDraw() override; |
| 64 scoped_ptr<cc::CompositorFrame> DemandDrawHw( | 69 scoped_ptr<cc::CompositorFrame> DemandDrawHw( |
| 65 gfx::Size surface_size, | 70 gfx::Size surface_size, |
| 66 const gfx::Transform& transform, | 71 const gfx::Transform& transform, |
| 67 gfx::Rect viewport, | 72 gfx::Rect viewport, |
| 68 gfx::Rect clip, | 73 gfx::Rect clip, |
| 69 gfx::Rect viewport_rect_for_tile_priority, | 74 gfx::Rect viewport_rect_for_tile_priority, |
| 70 const gfx::Transform& transform_for_tile_priority) override; | 75 const gfx::Transform& transform_for_tile_priority) override; |
| 71 bool DemandDrawSw(SkCanvas* canvas) override; | 76 bool DemandDrawSw(SkCanvas* canvas) override; |
| 72 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; | 77 void ReturnResources(const cc::CompositorFrameAck& frame_ack) override; |
| 73 void SetMemoryPolicy(size_t bytes_limit) override; | 78 void SetMemoryPolicy(size_t bytes_limit) override; |
| 74 void DidChangeRootLayerScrollOffset() override; | 79 void DidChangeRootLayerScrollOffset() override; |
| 80 void SetIsActive(bool is_active) override; |
| 81 void SendBeginFrame(cc::BeginFrameArgs args) 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(); | |
| 100 void DeliverMessages(); | 106 void DeliverMessages(); |
| 101 bool CalledOnValidThread() const; | 107 bool CalledOnValidThread() const; |
| 108 void UpdateNeedsBeginFrames(); |
| 102 | 109 |
| 103 SynchronousCompositorClient* compositor_client_; | 110 SynchronousCompositorClient* compositor_client_; |
| 104 SynchronousCompositorOutputSurface* output_surface_; | 111 SynchronousCompositorOutputSurface* output_surface_; |
| 105 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; | 112 SynchronousCompositorExternalBeginFrameSource* begin_frame_source_; |
| 106 WebContents* contents_; | 113 WebContents* contents_; |
| 107 const int routing_id_; | 114 const int routing_id_; |
| 108 cc::InputHandler* input_handler_; | 115 cc::InputHandler* input_handler_; |
| 109 bool invoking_composite_; | 116 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 |