Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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_COMPOSITOR_IMPL_ANDROID_H_ | 5 #ifndef CONTENT_BROWSER_RENDERER_HOST_COMPOSITOR_IMPL_ANDROID_H_ |
| 6 #define CONTENT_BROWSER_RENDERER_HOST_COMPOSITOR_IMPL_ANDROID_H_ | 6 #define CONTENT_BROWSER_RENDERER_HOST_COMPOSITOR_IMPL_ANDROID_H_ |
| 7 | 7 |
| 8 #include "base/basictypes.h" | 8 #include "base/basictypes.h" |
| 9 #include "base/compiler_specific.h" | 9 #include "base/compiler_specific.h" |
| 10 #include "base/containers/scoped_ptr_hash_map.h" | 10 #include "base/containers/scoped_ptr_hash_map.h" |
| 11 #include "base/memory/scoped_ptr.h" | 11 #include "base/memory/scoped_ptr.h" |
| 12 #include "base/memory/weak_ptr.h" | |
| 12 #include "cc/resources/ui_resource_client.h" | 13 #include "cc/resources/ui_resource_client.h" |
| 13 #include "cc/trees/layer_tree_host_client.h" | 14 #include "cc/trees/layer_tree_host_client.h" |
| 14 #include "cc/trees/layer_tree_host_single_thread_client.h" | 15 #include "cc/trees/layer_tree_host_single_thread_client.h" |
| 15 #include "content/browser/renderer_host/image_transport_factory_android.h" | 16 #include "content/browser/renderer_host/image_transport_factory_android.h" |
| 16 #include "content/common/content_export.h" | 17 #include "content/common/content_export.h" |
| 17 #include "content/public/browser/android/compositor.h" | 18 #include "content/public/browser/android/compositor.h" |
| 18 #include "third_party/khronos/GLES2/gl2.h" | 19 #include "third_party/khronos/GLES2/gl2.h" |
| 19 #include "ui/base/android/window_android_compositor.h" | 20 #include "ui/base/android/window_android_compositor.h" |
| 20 | 21 |
| 21 class SkBitmap; | 22 class SkBitmap; |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 56 // Compositor implementation. | 57 // Compositor implementation. |
| 57 virtual void SetRootLayer(scoped_refptr<cc::Layer> root) OVERRIDE; | 58 virtual void SetRootLayer(scoped_refptr<cc::Layer> root) OVERRIDE; |
| 58 virtual void SetWindowSurface(ANativeWindow* window) OVERRIDE; | 59 virtual void SetWindowSurface(ANativeWindow* window) OVERRIDE; |
| 59 virtual void SetSurface(jobject surface) OVERRIDE; | 60 virtual void SetSurface(jobject surface) OVERRIDE; |
| 60 virtual void SetVisible(bool visible) OVERRIDE; | 61 virtual void SetVisible(bool visible) OVERRIDE; |
| 61 virtual void setDeviceScaleFactor(float factor) OVERRIDE; | 62 virtual void setDeviceScaleFactor(float factor) OVERRIDE; |
| 62 virtual void SetWindowBounds(const gfx::Size& size) OVERRIDE; | 63 virtual void SetWindowBounds(const gfx::Size& size) OVERRIDE; |
| 63 virtual void SetHasTransparentBackground(bool flag) OVERRIDE; | 64 virtual void SetHasTransparentBackground(bool flag) OVERRIDE; |
| 64 virtual bool CompositeAndReadback( | 65 virtual bool CompositeAndReadback( |
| 65 void *pixels, const gfx::Rect& rect) OVERRIDE; | 66 void *pixels, const gfx::Rect& rect) OVERRIDE; |
| 66 virtual void Composite() OVERRIDE; | 67 virtual void SetNeedsComposite() OVERRIDE; |
| 67 virtual cc::UIResourceId GenerateUIResource(const SkBitmap& bitmap, | 68 virtual cc::UIResourceId GenerateUIResource(const SkBitmap& bitmap, |
| 68 bool is_transient) OVERRIDE; | 69 bool is_transient) OVERRIDE; |
| 69 virtual cc::UIResourceId GenerateCompressedUIResource(const gfx::Size& size, | 70 virtual cc::UIResourceId GenerateCompressedUIResource(const gfx::Size& size, |
| 70 void* pixels, | 71 void* pixels, |
| 71 bool is_transient) | 72 bool is_transient) |
| 72 OVERRIDE; | 73 OVERRIDE; |
| 73 virtual void DeleteUIResource(cc::UIResourceId resource_id) OVERRIDE; | 74 virtual void DeleteUIResource(cc::UIResourceId resource_id) OVERRIDE; |
| 74 | 75 |
| 75 // LayerTreeHostClient implementation. | 76 // LayerTreeHostClient implementation. |
| 76 virtual void WillBeginMainFrame(int frame_id) OVERRIDE {} | 77 virtual void WillBeginMainFrame(int frame_id) OVERRIDE {} |
| 77 virtual void DidBeginMainFrame() OVERRIDE {} | 78 virtual void DidBeginMainFrame() OVERRIDE {} |
| 78 virtual void Animate(base::TimeTicks frame_begin_time) OVERRIDE {} | 79 virtual void Animate(base::TimeTicks frame_begin_time) OVERRIDE {} |
| 79 virtual void Layout() OVERRIDE {} | 80 virtual void Layout() OVERRIDE; |
| 80 virtual void ApplyScrollAndScale(const gfx::Vector2d& scroll_delta, | 81 virtual void ApplyScrollAndScale(const gfx::Vector2d& scroll_delta, |
| 81 float page_scale) OVERRIDE {} | 82 float page_scale) OVERRIDE {} |
| 82 virtual scoped_ptr<cc::OutputSurface> CreateOutputSurface(bool fallback) | 83 virtual scoped_ptr<cc::OutputSurface> CreateOutputSurface(bool fallback) |
| 83 OVERRIDE; | 84 OVERRIDE; |
| 84 virtual void DidInitializeOutputSurface() OVERRIDE {} | 85 virtual void DidInitializeOutputSurface() OVERRIDE {} |
| 85 virtual void WillCommit() OVERRIDE {} | 86 virtual void WillCommit() OVERRIDE {} |
| 86 virtual void DidCommit() OVERRIDE; | 87 virtual void DidCommit() OVERRIDE; |
| 87 virtual void DidCommitAndDrawFrame() OVERRIDE {} | 88 virtual void DidCommitAndDrawFrame() OVERRIDE {} |
| 88 virtual void DidCompleteSwapBuffers() OVERRIDE; | 89 virtual void DidCompleteSwapBuffers() OVERRIDE; |
| 89 | 90 |
| 90 // LayerTreeHostSingleThreadClient implementation. | 91 // LayerTreeHostSingleThreadClient implementation. |
| 91 virtual void ScheduleComposite() OVERRIDE; | 92 virtual void ScheduleComposite() OVERRIDE; |
| 92 virtual void ScheduleAnimation() OVERRIDE; | 93 virtual void ScheduleAnimation() OVERRIDE; |
| 93 virtual void DidPostSwapBuffers() OVERRIDE; | 94 virtual void DidPostSwapBuffers() OVERRIDE; |
| 94 virtual void DidAbortSwapBuffers() OVERRIDE; | 95 virtual void DidAbortSwapBuffers() OVERRIDE; |
| 95 | 96 |
| 96 // ImageTransportFactoryAndroidObserver implementation. | 97 // ImageTransportFactoryAndroidObserver implementation. |
| 97 virtual void OnLostResources() OVERRIDE; | 98 virtual void OnLostResources() OVERRIDE; |
| 98 | 99 |
| 99 // WindowAndroidCompositor implementation. | 100 // WindowAndroidCompositor implementation. |
| 100 virtual void AttachLayerForReadback(scoped_refptr<cc::Layer> layer) OVERRIDE; | 101 virtual void AttachLayerForReadback(scoped_refptr<cc::Layer> layer) OVERRIDE; |
| 102 virtual void OnVSync(base::TimeTicks frame_time, | |
| 103 base::TimeDelta vsync_period) OVERRIDE; | |
| 101 | 104 |
| 102 private: | 105 private: |
| 106 void PostComposite(base::TimeDelta delay); | |
| 107 void Composite(bool is_vsync); | |
|
Sami
2014/05/09 13:21:14
Mind making this an enum -- CompositingTrigger or
no sievers
2014/05/09 22:53:44
Done.
| |
| 103 cc::UIResourceId GenerateUIResourceFromUIResourceBitmap( | 108 cc::UIResourceId GenerateUIResourceFromUIResourceBitmap( |
| 104 const cc::UIResourceBitmap& bitmap, | 109 const cc::UIResourceBitmap& bitmap, |
| 105 bool is_transient); | 110 bool is_transient); |
| 106 | 111 |
| 107 scoped_refptr<cc::Layer> root_layer_; | 112 scoped_refptr<cc::Layer> root_layer_; |
| 108 scoped_ptr<cc::LayerTreeHost> host_; | 113 scoped_ptr<cc::LayerTreeHost> host_; |
| 109 | 114 |
| 110 gfx::Size size_; | 115 gfx::Size size_; |
| 111 bool has_transparent_background_; | 116 bool has_transparent_background_; |
| 112 float device_scale_factor_; | 117 float device_scale_factor_; |
| 113 | 118 |
| 114 ANativeWindow* window_; | 119 ANativeWindow* window_; |
| 115 int surface_id_; | 120 int surface_id_; |
| 116 | 121 |
| 117 CompositorClient* client_; | 122 CompositorClient* client_; |
| 118 | 123 |
| 119 typedef base::ScopedPtrHashMap<cc::UIResourceId, cc::UIResourceClient> | 124 typedef base::ScopedPtrHashMap<cc::UIResourceId, cc::UIResourceClient> |
| 120 UIResourceMap; | 125 UIResourceMap; |
| 121 UIResourceMap ui_resource_map_; | 126 UIResourceMap ui_resource_map_; |
| 122 | 127 |
| 123 gfx::NativeWindow root_window_; | 128 gfx::NativeWindow root_window_; |
| 124 | 129 |
| 130 // Used locally to track whether a call to LTH::Composite() did result in | |
| 131 // a posted SwapBuffers(). | |
| 132 bool did_post_swapbuffers_; | |
| 133 | |
| 134 // Used locally to inhibit ScheduleComposite() during Layout(). | |
| 135 bool ignore_schedule_composite_; | |
| 136 | |
| 137 // Whether we need to composite in general because of any invalidation or | |
| 138 // explicit request. | |
| 139 bool needs_composite_; | |
| 140 | |
| 141 // When SetNeedsComposite() is getting called, we will try to schedule | |
|
Sami
2014/05/09 13:21:14
This explanation should probably go next to SetNee
no sievers
2014/05/09 22:53:44
ScheduleComposite is the LTHClient implementation.
| |
| 142 // regularly during vsync. | |
| 143 bool should_composite_on_vsync_; | |
| 144 | |
| 145 // Whether we composited immediately outside of a vsync callback since | |
| 146 // the last tick. | |
| 147 bool did_composite_outside_vsync_; | |
|
Sami
2014/05/09 13:21:14
Would something did_composite_during_this_frame_ b
no sievers
2014/05/09 22:53:44
Done.
| |
| 148 | |
| 149 // The number of SwapBuffer calls that have not returned and ACK'd from | |
| 150 // the GPU thread. | |
| 151 unsigned int pending_swapbuffers_; | |
| 152 | |
| 153 base::TimeDelta vsync_period_; | |
| 154 | |
| 155 base::WeakPtrFactory<CompositorImpl> weak_factory_; | |
| 156 | |
| 125 DISALLOW_COPY_AND_ASSIGN(CompositorImpl); | 157 DISALLOW_COPY_AND_ASSIGN(CompositorImpl); |
| 126 }; | 158 }; |
| 127 | 159 |
| 128 } // namespace content | 160 } // namespace content |
| 129 | 161 |
| 130 #endif // CONTENT_BROWSER_RENDERER_HOST_COMPOSITOR_IMPL_ANDROID_H_ | 162 #endif // CONTENT_BROWSER_RENDERER_HOST_COMPOSITOR_IMPL_ANDROID_H_ |
| OLD | NEW |