Chromium Code Reviews| 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 surface_manager, |
| 22 frame_sink_id, | 22 frame_sink_id, |
| 23 display.get(), | |
| 24 std::move(compositor_frame_sink_private_request), | 23 std::move(compositor_frame_sink_private_request), |
| 25 std::move(client)), | 24 std::move(client), |
| 25 true /* has_display */), | |
| 26 binding_(this, std::move(request)), | 26 binding_(this, std::move(request)), |
| 27 display_private_binding_(this, std::move(display_private_request)), | 27 display_private_binding_(this, std::move(display_private_request)), |
| 28 display_begin_frame_source_(std::move(begin_frame_source)), | 28 display_begin_frame_source_(std::move(begin_frame_source)), |
| 29 display_(std::move(display)) { | 29 display_(std::move(display)) { |
| 30 binding_.set_connection_error_handler( | 30 binding_.set_connection_error_handler( |
| 31 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, | 31 base::Bind(&GpuDisplayCompositorFrameSink::OnClientConnectionLost, |
| 32 base::Unretained(this))); | 32 base::Unretained(this))); |
| 33 display_->Initialize(this, surface_manager); | |
| 33 display_->SetVisible(true); | 34 display_->SetVisible(true); |
| 34 } | 35 } |
| 35 | 36 |
| 36 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; | 37 GpuDisplayCompositorFrameSink::~GpuDisplayCompositorFrameSink() = default; |
| 37 | 38 |
| 39 void GpuDisplayCompositorFrameSink::SubmitCompositorFrame( | |
|
danakj
2017/02/08 19:23:38
Overloading a method that has an impl in the paren
Alex Z.
2017/02/08 21:26:47
As discussed on slack, DisplayPrivate::SetLocalSur
| |
| 40 const cc::LocalSurfaceId& local_surface_id, | |
| 41 cc::CompositorFrame frame) { | |
| 42 display_->SetLocalSurfaceId(local_surface_id, | |
| 43 frame.metadata.device_scale_factor); | |
| 44 | |
| 45 GpuCompositorFrameSink::SubmitCompositorFrame(local_surface_id, | |
| 46 std::move(frame)); | |
| 47 } | |
| 48 | |
| 38 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { | 49 void GpuDisplayCompositorFrameSink::SetDisplayVisible(bool visible) { |
| 39 DCHECK(support_.display()); | 50 DCHECK(display_); |
| 40 display_->SetVisible(visible); | 51 display_->SetVisible(visible); |
| 41 } | 52 } |
| 42 | 53 |
| 43 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { | 54 void GpuDisplayCompositorFrameSink::ResizeDisplay(const gfx::Size& size) { |
| 44 DCHECK(support_.display()); | 55 DCHECK(display_); |
| 45 display_->Resize(size); | 56 display_->Resize(size); |
| 46 } | 57 } |
| 47 | 58 |
| 48 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( | 59 void GpuDisplayCompositorFrameSink::SetDisplayColorSpace( |
| 49 const gfx::ColorSpace& color_space) { | 60 const gfx::ColorSpace& color_space) { |
| 50 DCHECK(support_.display()); | 61 DCHECK(display_); |
| 51 display_->SetColorSpace(color_space); | 62 display_->SetColorSpace(color_space); |
| 52 } | 63 } |
| 53 | 64 |
| 54 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { | 65 void GpuDisplayCompositorFrameSink::SetOutputIsSecure(bool secure) { |
| 55 DCHECK(support_.display()); | 66 DCHECK(display_); |
| 56 display_->SetOutputIsSecure(secure); | 67 display_->SetOutputIsSecure(secure); |
| 57 } | 68 } |
| 58 | 69 |
| 70 void GpuDisplayCompositorFrameSink::DisplayOutputSurfaceLost() {} | |
|
danakj
2017/02/08 19:23:38
Why does the client not want to hear about the con
Alex Z.
2017/02/08 21:26:47
The client_ (assuming we are changing it from priv
danakj
2017/02/08 21:42:43
If the display's context/outputsurface is lost, th
Alex Z.
2017/02/08 21:50:08
I added a TODO here.
| |
| 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 |