| 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 std::move(display), | 23 surface_manager, |
| 24 std::move(begin_frame_source), | 24 frame_sink_id, |
| 25 true /* submits_to_display_compositor */), |
| 25 std::move(compositor_frame_sink_private_request), | 26 std::move(compositor_frame_sink_private_request), |
| 26 std::move(client)), | 27 std::move(client)), |
| 27 binding_(this, std::move(request)), | 28 binding_(this, std::move(request)), |
| 28 display_private_binding_(this, std::move(display_private_request)) { | 29 display_private_binding_(this, std::move(display_private_request)), |
| 30 display_begin_frame_source_(std::move(begin_frame_source)), |
| 31 display_(std::move(display)) { |
| 29 binding_.set_connection_error_handler( | 32 binding_.set_connection_error_handler( |
| 30 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, | 33 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, |
| 31 base::Unretained(this))); | 34 base::Unretained(this))); |
| 35 display_->Initialize(this, surface_manager); |
| 36 display_->SetVisible(true); |
| 32 } | 37 } |
| 33 | 38 |
| 34 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; | 39 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; |
| 35 | 40 |
| 36 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { | 41 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { |
| 37 DCHECK(support_.display()); | 42 DCHECK(display_); |
| 38 support_.display()->SetVisible(visible); | 43 display_->SetVisible(visible); |
| 39 } | 44 } |
| 40 | 45 |
| 41 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { | 46 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { |
| 42 DCHECK(support_.display()); | 47 DCHECK(display_); |
| 43 support_.display()->Resize(size); | 48 display_->Resize(size); |
| 44 } | 49 } |
| 45 | 50 |
| 46 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( | 51 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( |
| 47 const gfx::ColorSpace& color_space) { | 52 const gfx::ColorSpace& color_space) { |
| 48 DCHECK(support_.display()); | 53 DCHECK(display_); |
| 49 support_.display()->SetColorSpace(color_space); | 54 display_->SetColorSpace(color_space); |
| 50 } | 55 } |
| 51 | 56 |
| 52 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { | 57 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { |
| 53 DCHECK(support_.display()); | 58 DCHECK(display_); |
| 54 support_.display()->SetOutputIsSecure(secure); | 59 display_->SetOutputIsSecure(secure); |
| 55 } | 60 } |
| 56 | 61 |
| 62 void GpuDisplayCompositorFrameSink::SetLocalSurfaceId( |
| 63 const cc::LocalSurfaceId& local_surface_id, |
| 64 float scale_factor) { |
| 65 display_->SetLocalSurfaceId(local_surface_id, scale_factor); |
| 66 } |
| 67 |
| 68 void GpuDisplayCompositorFrameSink::DisplayOutputSurfaceLost() { |
| 69 // TODO(staraz): Implement this. Client should hear about context/output |
| 70 // surface lost. |
| 71 } |
| 72 |
| 73 void GpuDisplayCompositorFrameSink::DisplayWillDrawAndSwap( |
| 74 bool will_draw_and_swap, |
| 75 const cc::RenderPassList& render_pass) {} |
| 76 |
| 77 void GpuDisplayCompositorFrameSink::DisplayDidDrawAndSwap() {} |
| 78 |
| 57 } // namespace display_compositor | 79 } // namespace display_compositor |
| OLD | NEW |