Chromium Code Reviews| 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 |