OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "android_webview/browser/parent_output_surface.h" | 5 #include "android_webview/browser/parent_output_surface.h" |
6 | 6 |
7 #include "android_webview/browser/aw_render_thread_context_provider.h" | 7 #include "android_webview/browser/aw_render_thread_context_provider.h" |
8 #include "cc/output/output_surface_client.h" | 8 #include "cc/output/output_surface_client.h" |
9 #include "gpu/command_buffer/client/gles2_interface.h" | 9 #include "gpu/command_buffer/client/gles2_interface.h" |
10 | 10 |
(...skipping 13 matching lines...) Expand all Loading... |
24 LOG(FATAL) << "Render thread context loss"; | 24 LOG(FATAL) << "Render thread context loss"; |
25 } | 25 } |
26 | 26 |
27 void ParentOutputSurface::Reshape(const gfx::Size& size, | 27 void ParentOutputSurface::Reshape(const gfx::Size& size, |
28 float scale_factor, | 28 float scale_factor, |
29 bool has_alpha) { | 29 bool has_alpha) { |
30 DCHECK_EQ(1.f, scale_factor); | 30 DCHECK_EQ(1.f, scale_factor); |
31 surface_size_ = size; | 31 surface_size_ = size; |
32 } | 32 } |
33 | 33 |
34 void ParentOutputSurface::SwapBuffers(cc::CompositorFrame* frame) { | 34 void ParentOutputSurface::SwapBuffers( |
| 35 std::unique_ptr<cc::CompositorFrame> frame) { |
35 context_provider_->ContextGL()->ShallowFlushCHROMIUM(); | 36 context_provider_->ContextGL()->ShallowFlushCHROMIUM(); |
36 client_->DidSwapBuffers(); | 37 client_->DidSwapBuffers(); |
37 } | 38 } |
38 | 39 |
39 void ParentOutputSurface::ApplyExternalStencil() { | 40 void ParentOutputSurface::ApplyExternalStencil() { |
40 DCHECK(stencil_state_.stencil_test_enabled); | 41 DCHECK(stencil_state_.stencil_test_enabled); |
41 gpu::gles2::GLES2Interface* gl = context_provider()->ContextGL(); | 42 gpu::gles2::GLES2Interface* gl = context_provider()->ContextGL(); |
42 gl->StencilFuncSeparate(GL_FRONT, stencil_state_.stencil_front_func, | 43 gl->StencilFuncSeparate(GL_FRONT, stencil_state_.stencil_front_func, |
43 stencil_state_.stencil_front_mask, | 44 stencil_state_.stencil_front_mask, |
44 stencil_state_.stencil_front_ref); | 45 stencil_state_.stencil_front_ref); |
(...skipping 14 matching lines...) Expand all Loading... |
59 auto* gl = static_cast<AwRenderThreadContextProvider*>(context_provider()); | 60 auto* gl = static_cast<AwRenderThreadContextProvider*>(context_provider()); |
60 return gl->GetCopyTextureInternalFormat(); | 61 return gl->GetCopyTextureInternalFormat(); |
61 } | 62 } |
62 | 63 |
63 void ParentOutputSurface::SetGLState(const ScopedAppGLStateRestore& gl_state) { | 64 void ParentOutputSurface::SetGLState(const ScopedAppGLStateRestore& gl_state) { |
64 stencil_state_ = gl_state.stencil_state(); | 65 stencil_state_ = gl_state.stencil_state(); |
65 SetExternalStencilTest(stencil_state_.stencil_test_enabled); | 66 SetExternalStencilTest(stencil_state_.stencil_test_enabled); |
66 } | 67 } |
67 | 68 |
68 } // namespace android_webview | 69 } // namespace android_webview |
OLD | NEW |