| OLD | NEW |
| 1 // Copyright 2017 The Chromium Authors. All rights reserved. | 1 // Copyright 2017 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 "components/display_compositor/gpu_display_compositor_frame_sink.h" | 5 #include "components/display_compositor/gpu_display_compositor_frame_sink.h" |
| 6 | 6 |
| 7 namespace display_compositor { | 7 namespace display_compositor { |
| 8 | 8 |
| 9 GpuDisplayCompositorFrameSink::GpuDisplayCompositorFrameSink( | 9 GpuDisplayCompositorFrameSink::GpuDisplayCompositorFrameSink( |
| 10 GpuCompositorFrameSinkDelegate* delegate, | 10 GpuCompositorFrameSinkDelegate* delegate, |
| 11 cc::SurfaceManager* surface_manager, | 11 cc::SurfaceManager* surface_manager, |
| 12 const cc::FrameSinkId& frame_sink_id, | 12 const cc::FrameSinkId& frame_sink_id, |
| 13 std::unique_ptr<cc::Display> display, | 13 std::unique_ptr<cc::Display> display, |
| 14 std::unique_ptr<cc::BeginFrameSource> begin_frame_source, | 14 std::unique_ptr<cc::BeginFrameSource> begin_frame_source, |
| 15 cc::mojom::MojoCompositorFrameSinkAssociatedRequest request, | 15 cc::mojom::MojoCompositorFrameSinkAssociatedRequest request, |
| 16 cc::mojom::MojoCompositorFrameSinkPrivateRequest | 16 cc::mojom::MojoCompositorFrameSinkPrivateRequest |
| 17 compositor_frame_sink_private_request, | 17 compositor_frame_sink_private_request, |
| 18 cc::mojom::MojoCompositorFrameSinkClientPtr client, | 18 cc::mojom::MojoCompositorFrameSinkClientPtr client, |
| 19 cc::mojom::DisplayPrivateAssociatedRequest display_private_request) | 19 cc::mojom::DisplayPrivateAssociatedRequest display_private_request) |
| 20 : GpuCompositorFrameSink(delegate, | 20 : GpuCompositorFrameSink(delegate, |
| 21 surface_manager, | 21 base::MakeUnique<cc::CompositorFrameSinkSupport>( |
| 22 frame_sink_id, | 22 this, |
| 23 display.get(), | 23 surface_manager, |
| 24 frame_sink_id, |
| 25 true /* handles_frame_sink_id_invalidation */, |
| 26 true /* needs_sync_points */, |
| 27 true /* submits_to_display_compositor */), |
| 24 std::move(compositor_frame_sink_private_request), | 28 std::move(compositor_frame_sink_private_request), |
| 25 std::move(client)), | 29 std::move(client)), |
| 26 binding_(this, std::move(request)), | 30 binding_(this, std::move(request)), |
| 27 display_private_binding_(this, std::move(display_private_request)), | 31 display_private_binding_(this, std::move(display_private_request)), |
| 28 display_begin_frame_source_(std::move(begin_frame_source)), | 32 display_begin_frame_source_(std::move(begin_frame_source)), |
| 29 display_(std::move(display)) { | 33 display_(std::move(display)) { |
| 30 binding_.set_connection_error_handler( | 34 binding_.set_connection_error_handler( |
| 31 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, | 35 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, |
| 32 base::Unretained(this))); | 36 base::Unretained(this))); |
| 37 display_->Initialize(this, surface_manager); |
| 33 display_->SetVisible(true); | 38 display_->SetVisible(true); |
| 34 } | 39 } |
| 35 | 40 |
| 36 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; | 41 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; |
| 37 | 42 |
| 38 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { | 43 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { |
| 39 DCHECK(support_.display()); | 44 DCHECK(display_); |
| 40 display_->SetVisible(visible); | 45 display_->SetVisible(visible); |
| 41 } | 46 } |
| 42 | 47 |
| 43 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { | 48 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { |
| 44 DCHECK(support_.display()); | 49 DCHECK(display_); |
| 45 display_->Resize(size); | 50 display_->Resize(size); |
| 46 } | 51 } |
| 47 | 52 |
| 48 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( | 53 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( |
| 49 const gfx::ColorSpace& color_space) { | 54 const gfx::ColorSpace& color_space) { |
| 50 DCHECK(support_.display()); | 55 DCHECK(display_); |
| 51 display_->SetColorSpace(color_space); | 56 display_->SetColorSpace(color_space); |
| 52 } | 57 } |
| 53 | 58 |
| 54 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { | 59 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { |
| 55 DCHECK(support_.display()); | 60 DCHECK(display_); |
| 56 display_->SetOutputIsSecure(secure); | 61 display_->SetOutputIsSecure(secure); |
| 57 } | 62 } |
| 58 | 63 |
| 64 void GpuDisplayCompositorFrameSink::SetLocalSurfaceId( |
| 65 const cc::LocalSurfaceId& local_surface_id, |
| 66 float scale_factor) { |
| 67 display_->SetLocalSurfaceId(local_surface_id, scale_factor); |
| 68 } |
| 69 |
| 70 void GpuDisplayCompositorFrameSink::DisplayOutputSurfaceLost() {} |
| 71 |
| 72 void GpuDisplayCompositorFrameSink::DisplayWillDrawAndSwap( |
| 73 bool will_draw_and_swap, |
| 74 const cc::RenderPassList& render_passes) {} |
| 75 |
| 76 void GpuDisplayCompositorFrameSink::DisplayDidDrawAndSwap() {} |
| 77 |
| 59 } // namespace display_compositor | 78 } // namespace display_compositor |
| OLD | NEW |