| 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 #include "webkit/compositor_bindings/web_layer_tree_view_impl_for_testing.h" | 5 #include "webkit/compositor_bindings/web_layer_tree_view_impl_for_testing.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/string_number_conversions.h" | 8 #include "base/string_number_conversions.h" |
| 9 #include "base/synchronization/lock.h" | 9 #include "base/synchronization/lock.h" |
| 10 #include "cc/context_provider.h" | 10 #include "cc/context_provider.h" |
| 11 #include "cc/fake_web_graphics_context_3d.h" | 11 #include "cc/fake_web_graphics_context_3d.h" |
| 12 #include "cc/input_handler.h" | 12 #include "cc/input_handler.h" |
| 13 #include "cc/layer.h" | 13 #include "cc/layer.h" |
| 14 #include "cc/layer_tree_host.h" | 14 #include "cc/layer_tree_host.h" |
| 15 #include "cc/output_surface.h" | 15 #include "cc/output_surface.h" |
| 16 #include "cc/switches.h" | 16 #include "cc/switches.h" |
| 17 #include "cc/thread.h" | 17 #include "cc/thread.h" |
| 18 #include "cc/thread_impl.h" | 18 #include "cc/thread_impl.h" |
| 19 #include "third_party/WebKit/Source/Platform/chromium/public/Platform.h" | 19 #include "third_party/WebKit/Source/Platform/chromium/public/Platform.h" |
| 20 #include "third_party/WebKit/Source/Platform/chromium/public/WebGraphicsContext3
D.h" | 20 #include "third_party/WebKit/Source/Platform/chromium/public/WebGraphicsContext3
D.h" |
| 21 #include "third_party/WebKit/Source/Platform/chromium/public/WebInputHandler.h" | 21 #include "third_party/WebKit/Source/Platform/chromium/public/WebInputHandler.h" |
| 22 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayer.h" | 22 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayer.h" |
| 23 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayerTreeView.h" | 23 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayerTreeView.h" |
| 24 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayerTreeViewCli
ent.h" | 24 #include "third_party/WebKit/Source/Platform/chromium/public/WebLayerTreeViewCli
ent.h" |
| 25 #include "third_party/WebKit/Source/Platform/chromium/public/WebRenderingStats.h
" | 25 #include "third_party/WebKit/Source/Platform/chromium/public/WebRenderingStats.h
" |
| 26 #include "third_party/WebKit/Source/Platform/chromium/public/WebSharedGraphicsCo
ntext3D.h" | |
| 27 #include "third_party/WebKit/Source/Platform/chromium/public/WebSize.h" | 26 #include "third_party/WebKit/Source/Platform/chromium/public/WebSize.h" |
| 28 #include "webkit/compositor_bindings/web_compositor_support_impl.h" | 27 #include "webkit/compositor_bindings/web_compositor_support_impl.h" |
| 29 #include "webkit/compositor_bindings/web_compositor_support_software_output_devi
ce.h" | 28 #include "webkit/compositor_bindings/web_compositor_support_software_output_devi
ce.h" |
| 30 #include "webkit/compositor_bindings/web_layer_impl.h" | 29 #include "webkit/compositor_bindings/web_layer_impl.h" |
| 31 #include "webkit/compositor_bindings/web_rendering_stats_impl.h" | 30 #include "webkit/compositor_bindings/web_rendering_stats_impl.h" |
| 32 #include "webkit/compositor_bindings/web_to_ccinput_handler_adapter.h" | 31 #include "webkit/compositor_bindings/web_to_ccinput_handler_adapter.h" |
| 33 #include "webkit/gpu/webgraphicscontext3d_in_process_command_buffer_impl.h" | 32 #include "webkit/gpu/test_context_provider_factory.h" |
| 33 #include "webkit/support/test_webkit_platform_support.h" |
| 34 | 34 |
| 35 namespace WebKit { | 35 namespace WebKit { |
| 36 | 36 |
| 37 WebLayerTreeViewImplForTesting::WebLayerTreeViewImplForTesting( | 37 WebLayerTreeViewImplForTesting::WebLayerTreeViewImplForTesting( |
| 38 RenderingType type, | 38 RenderingType type, |
| 39 WebKit::WebLayerTreeViewClient* client) | 39 WebKit::WebLayerTreeViewClient* client) |
| 40 : type_(type), client_(client) {} | 40 : type_(type), |
| 41 client_(client) {} |
| 41 | 42 |
| 42 WebLayerTreeViewImplForTesting::~WebLayerTreeViewImplForTesting() {} | 43 WebLayerTreeViewImplForTesting::~WebLayerTreeViewImplForTesting() { |
| 44 } |
| 43 | 45 |
| 44 bool WebLayerTreeViewImplForTesting::initialize( | 46 bool WebLayerTreeViewImplForTesting::initialize( |
| 45 scoped_ptr<cc::Thread> compositor_thread) { | 47 scoped_ptr<cc::Thread> compositor_thread) { |
| 46 cc::LayerTreeSettings settings; | 48 cc::LayerTreeSettings settings; |
| 47 // Accelerated animations are disabled for layout tests, but enabled for unit | 49 // Accelerated animations are disabled for layout tests, but enabled for unit |
| 48 // tests. | 50 // tests. |
| 49 settings.acceleratedAnimationEnabled = type_ == FAKE_CONTEXT; | 51 settings.acceleratedAnimationEnabled = type_ == FAKE_CONTEXT; |
| 50 layer_tree_host_ = | 52 layer_tree_host_ = |
| 51 cc::LayerTreeHost::create(this, settings, compositor_thread.Pass()); | 53 cc::LayerTreeHost::create(this, settings, compositor_thread.Pass()); |
| 52 if (!layer_tree_host_.get()) | 54 if (!layer_tree_host_.get()) |
| (...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 218 | 220 |
| 219 void WebLayerTreeViewImplForTesting::didCommitAndDrawFrame() {} | 221 void WebLayerTreeViewImplForTesting::didCommitAndDrawFrame() {} |
| 220 | 222 |
| 221 void WebLayerTreeViewImplForTesting::didCompleteSwapBuffers() {} | 223 void WebLayerTreeViewImplForTesting::didCompleteSwapBuffers() {} |
| 222 | 224 |
| 223 void WebLayerTreeViewImplForTesting::scheduleComposite() { | 225 void WebLayerTreeViewImplForTesting::scheduleComposite() { |
| 224 if (client_) | 226 if (client_) |
| 225 client_->scheduleComposite(); | 227 client_->scheduleComposite(); |
| 226 } | 228 } |
| 227 | 229 |
| 228 class WebLayerTreeViewImplForTesting::MainThreadContextProvider : | |
| 229 public cc::ContextProvider { | |
| 230 public: | |
| 231 virtual bool InitializeOnMainThread() OVERRIDE { return true; } | |
| 232 virtual bool BindToCurrentThread() OVERRIDE { return true; } | |
| 233 | |
| 234 virtual WebKit::WebGraphicsContext3D* Context3d() OVERRIDE { | |
| 235 return WebSharedGraphicsContext3D::mainThreadContext(); | |
| 236 } | |
| 237 virtual class GrContext* GrContext() OVERRIDE { | |
| 238 return WebSharedGraphicsContext3D::mainThreadGrContext(); | |
| 239 } | |
| 240 | |
| 241 virtual void VerifyContexts() OVERRIDE {} | |
| 242 | |
| 243 protected: | |
| 244 virtual ~MainThreadContextProvider() {} | |
| 245 }; | |
| 246 | |
| 247 scoped_refptr<cc::ContextProvider> | 230 scoped_refptr<cc::ContextProvider> |
| 248 WebLayerTreeViewImplForTesting::OffscreenContextProviderForMainThread() { | 231 WebLayerTreeViewImplForTesting::OffscreenContextProviderForMainThread() { |
| 249 if (!contexts_main_thread_) | 232 return webkit::gpu::TestContextProviderFactory::GetInstance()-> |
| 250 contexts_main_thread_ = new MainThreadContextProvider; | 233 OffscreenContextProviderForMainThread(); |
| 251 return contexts_main_thread_; | |
| 252 } | 234 } |
| 253 | 235 |
| 254 class WebLayerTreeViewImplForTesting::CompositorThreadContextProvider : | |
| 255 public cc::ContextProvider { | |
| 256 public: | |
| 257 CompositorThreadContextProvider() : destroyed_(false) {} | |
| 258 | |
| 259 virtual bool InitializeOnMainThread() OVERRIDE { | |
| 260 return WebSharedGraphicsContext3D::createCompositorThreadContext(); | |
| 261 } | |
| 262 virtual bool BindToCurrentThread() OVERRIDE { | |
| 263 return Context3d()->makeContextCurrent(); | |
| 264 } | |
| 265 | |
| 266 virtual WebKit::WebGraphicsContext3D* Context3d() OVERRIDE { | |
| 267 return WebSharedGraphicsContext3D::compositorThreadContext(); | |
| 268 } | |
| 269 virtual class GrContext* GrContext() OVERRIDE { | |
| 270 return WebSharedGraphicsContext3D::compositorThreadGrContext(); | |
| 271 } | |
| 272 | |
| 273 virtual void VerifyContexts() OVERRIDE { | |
| 274 if (Context3d() && !Context3d()->isContextLost()) | |
| 275 return; | |
| 276 base::AutoLock lock(destroyed_lock_); | |
| 277 destroyed_ = true; | |
| 278 } | |
| 279 | |
| 280 bool DestroyedOnMainThread() { | |
| 281 base::AutoLock lock(destroyed_lock_); | |
| 282 return destroyed_; | |
| 283 } | |
| 284 | |
| 285 protected: | |
| 286 virtual ~CompositorThreadContextProvider() {} | |
| 287 | |
| 288 private: | |
| 289 base::Lock destroyed_lock_; | |
| 290 bool destroyed_; | |
| 291 }; | |
| 292 | |
| 293 scoped_refptr<cc::ContextProvider> | 236 scoped_refptr<cc::ContextProvider> |
| 294 WebLayerTreeViewImplForTesting::OffscreenContextProviderForCompositorThread() { | 237 WebLayerTreeViewImplForTesting::OffscreenContextProviderForCompositorThread() { |
| 295 if (!contexts_compositor_thread_ || | 238 return webkit::gpu::TestContextProviderFactory::GetInstance()-> |
| 296 contexts_compositor_thread_->DestroyedOnMainThread()) | 239 OffscreenContextProviderForCompositorThread(); |
| 297 contexts_compositor_thread_ = new CompositorThreadContextProvider; | |
| 298 return contexts_compositor_thread_; | |
| 299 } | 240 } |
| 300 | 241 |
| 301 } // namespace WebKit | 242 } // namespace WebKit |
| OLD | NEW |