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 "content/browser/compositor/gpu_surfaceless_browser_compositor_output_s urface.h" | 5 #include "content/browser/compositor/gpu_surfaceless_browser_compositor_output_s urface.h" |
6 | 6 |
7 #include "cc/output/compositor_frame.h" | 7 #include "cc/output/compositor_frame.h" |
8 #include "content/browser/compositor/buffer_queue.h" | 8 #include "content/browser/compositor/buffer_queue.h" |
9 #include "content/browser/compositor/reflector_impl.h" | 9 #include "content/browser/compositor/reflector_impl.h" |
10 #include "content/browser/gpu/gpu_surface_tracker.h" | 10 #include "content/browser/gpu/gpu_surface_tracker.h" |
(...skipping 20 matching lines...) Expand all Loading... | |
31 } | 31 } |
32 | 32 |
33 GpuSurfacelessBrowserCompositorOutputSurface:: | 33 GpuSurfacelessBrowserCompositorOutputSurface:: |
34 ~GpuSurfacelessBrowserCompositorOutputSurface() { | 34 ~GpuSurfacelessBrowserCompositorOutputSurface() { |
35 } | 35 } |
36 | 36 |
37 void GpuSurfacelessBrowserCompositorOutputSurface::SwapBuffers( | 37 void GpuSurfacelessBrowserCompositorOutputSurface::SwapBuffers( |
38 cc::CompositorFrame* frame) { | 38 cc::CompositorFrame* frame) { |
39 DCHECK(output_surface_); | 39 DCHECK(output_surface_); |
40 | 40 |
41 output_surface_->SwapBuffers(frame->gl_frame_data->sub_buffer_rect); | |
42 // Disable the sub-buffer processing path on the parent classes, because we | |
43 // have handled it here. | |
44 frame->gl_frame_data->sub_buffer_rect = gfx::Rect(frame->gl_frame_data->size); | |
alexst (slow to review)
2014/09/18 15:39:15
We have a reflector, which is used for multimon mi
achaulk
2014/09/18 16:45:02
Done.
| |
45 | |
41 const gfx::Size& size = frame->gl_frame_data->size; | 46 const gfx::Size& size = frame->gl_frame_data->size; |
42 context_provider_->ContextGL()->ScheduleOverlayPlaneCHROMIUM( | 47 context_provider_->ContextGL()->ScheduleOverlayPlaneCHROMIUM( |
43 0, | 48 0, |
44 GL_OVERLAY_TRANSFORM_NONE_CHROMIUM, | 49 GL_OVERLAY_TRANSFORM_NONE_CHROMIUM, |
45 output_surface_->current_texture_id(), | 50 output_surface_->current_texture_id(), |
46 0, | 51 0, |
47 0, | 52 0, |
48 size.width(), | 53 size.width(), |
49 size.height(), | 54 size.height(), |
50 0, | 55 0, |
51 0, | 56 0, |
52 1.0f, | 57 1.0f, |
53 1.0f); | 58 1.0f); |
54 output_surface_->SwapBuffers(); | |
55 GpuBrowserCompositorOutputSurface::SwapBuffers(frame); | 59 GpuBrowserCompositorOutputSurface::SwapBuffers(frame); |
56 } | 60 } |
57 | 61 |
58 void GpuSurfacelessBrowserCompositorOutputSurface::OnSwapBuffersComplete() { | 62 void GpuSurfacelessBrowserCompositorOutputSurface::OnSwapBuffersComplete() { |
59 DCHECK(output_surface_); | 63 DCHECK(output_surface_); |
60 output_surface_->PageFlipComplete(); | 64 output_surface_->PageFlipComplete(); |
61 GpuBrowserCompositorOutputSurface::OnSwapBuffersComplete(); | 65 GpuBrowserCompositorOutputSurface::OnSwapBuffersComplete(); |
62 } | 66 } |
63 | 67 |
64 void GpuSurfacelessBrowserCompositorOutputSurface::BindFramebuffer() { | 68 void GpuSurfacelessBrowserCompositorOutputSurface::BindFramebuffer() { |
(...skipping 11 matching lines...) Expand all Loading... | |
76 | 80 |
77 bool GpuSurfacelessBrowserCompositorOutputSurface::BindToClient( | 81 bool GpuSurfacelessBrowserCompositorOutputSurface::BindToClient( |
78 cc::OutputSurfaceClient* client) { | 82 cc::OutputSurfaceClient* client) { |
79 if (!GpuBrowserCompositorOutputSurface::BindToClient(client)) | 83 if (!GpuBrowserCompositorOutputSurface::BindToClient(client)) |
80 return false; | 84 return false; |
81 output_surface_.reset(new BufferQueue(context_provider_, internalformat_)); | 85 output_surface_.reset(new BufferQueue(context_provider_, internalformat_)); |
82 return output_surface_->Initialize(); | 86 return output_surface_->Initialize(); |
83 } | 87 } |
84 | 88 |
85 } // namespace content | 89 } // namespace content |
OLD | NEW |