| 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 "content/browser/android/in_process/synchronous_compositor_impl.h" | 5 #include "content/browser/android/in_process/synchronous_compositor_impl.h" |
| 6 | 6 |
| 7 #include "base/auto_reset.h" | 7 #include "base/auto_reset.h" |
| 8 #include "base/bind.h" | 8 #include "base/bind.h" |
| 9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
| 10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
| (...skipping 134 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 145 if (compositor_client_) | 145 if (compositor_client_) |
| 146 compositor_client_->DidDestroyCompositor(this); | 146 compositor_client_->DidDestroyCompositor(this); |
| 147 compositor_client_ = nullptr; | 147 compositor_client_ = nullptr; |
| 148 } | 148 } |
| 149 | 149 |
| 150 bool SynchronousCompositorImpl::InitializeHwDraw() { | 150 bool SynchronousCompositorImpl::InitializeHwDraw() { |
| 151 DCHECK(CalledOnValidThread()); | 151 DCHECK(CalledOnValidThread()); |
| 152 DCHECK(output_surface_); | 152 DCHECK(output_surface_); |
| 153 | 153 |
| 154 scoped_refptr<cc::ContextProvider> onscreen_context = | 154 scoped_refptr<cc::ContextProvider> onscreen_context = |
| 155 g_factory.Get().CreateOnscreenContextProviderForCompositorThread(); | 155 g_factory.Get().CreateContextProviderForCompositor(); |
| 156 | 156 |
| 157 bool success = output_surface_->InitializeHwDraw(onscreen_context); | 157 scoped_refptr<cc::ContextProvider> worker_context = |
| 158 g_factory.Get().CreateContextProviderForCompositor(); |
| 159 |
| 160 bool success = |
| 161 output_surface_->InitializeHwDraw(onscreen_context, worker_context); |
| 158 | 162 |
| 159 if (success) | 163 if (success) |
| 160 g_factory.Get().CompositorInitializedHardwareDraw(); | 164 g_factory.Get().CompositorInitializedHardwareDraw(); |
| 161 return success; | 165 return success; |
| 162 } | 166 } |
| 163 | 167 |
| 164 void SynchronousCompositorImpl::ReleaseHwDraw() { | 168 void SynchronousCompositorImpl::ReleaseHwDraw() { |
| 165 DCHECK(CalledOnValidThread()); | 169 DCHECK(CalledOnValidThread()); |
| 166 DCHECK(output_surface_); | 170 DCHECK(output_surface_); |
| 167 output_surface_->ReleaseHwDraw(); | 171 output_surface_->ReleaseHwDraw(); |
| (...skipping 196 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 364 g_factory.Get(); // Ensure it's initialized. | 368 g_factory.Get(); // Ensure it's initialized. |
| 365 SynchronousCompositorImpl::CreateForWebContents(contents); | 369 SynchronousCompositorImpl::CreateForWebContents(contents); |
| 366 } | 370 } |
| 367 SynchronousCompositorImpl* instance = | 371 SynchronousCompositorImpl* instance = |
| 368 SynchronousCompositorImpl::FromWebContents(contents); | 372 SynchronousCompositorImpl::FromWebContents(contents); |
| 369 DCHECK(instance); | 373 DCHECK(instance); |
| 370 instance->SetClient(client); | 374 instance->SetClient(client); |
| 371 } | 375 } |
| 372 | 376 |
| 373 } // namespace content | 377 } // namespace content |
| OLD | NEW |