| 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 "content/browser/compositor/frame_sink_manager_host.h" | 5 #include "content/browser/compositor/frame_sink_manager_host.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "cc/surfaces/surface_info.h" | 9 #include "cc/surfaces/surface_info.h" |
| 10 #include "cc/surfaces/surface_manager.h" | 10 #include "cc/surfaces/surface_manager.h" |
| 11 | 11 |
| 12 namespace content { | 12 namespace content { |
| 13 | 13 |
| 14 FrameSinkManagerHost::FrameSinkManagerHost() | 14 FrameSinkManagerHost::FrameSinkManagerHost() |
| 15 : binding_(this), | 15 : binding_(this), |
| 16 frame_sink_manager_(false, // Use surface sequences. | 16 frame_sink_manager_(false, // Use surface sequences. |
| 17 nullptr, | 17 nullptr, |
| 18 MakeRequest(&frame_sink_manager_ptr_), | 18 MakeRequest(&frame_sink_manager_ptr_), |
| 19 binding_.CreateInterfacePtrAndBind()) {} | 19 binding_.CreateInterfacePtrAndBind()) {} |
| 20 | 20 |
| 21 FrameSinkManagerHost::~FrameSinkManagerHost() {} | 21 FrameSinkManagerHost::~FrameSinkManagerHost() {} |
| 22 | 22 |
| 23 cc::SurfaceManager* FrameSinkManagerHost::surface_manager() { | 23 cc::SurfaceManager* FrameSinkManagerHost::surface_manager() { |
| 24 return frame_sink_manager_.surface_manager(); | 24 return frame_sink_manager_.surface_manager(); |
| 25 } | 25 } |
| 26 | 26 |
| 27 void FrameSinkManagerHost::AddObserver(cc::SurfaceObserver* observer) { |
| 28 observers_.AddObserver(observer); |
| 29 } |
| 30 |
| 31 void FrameSinkManagerHost::RemoveObserver(cc::SurfaceObserver* observer) { |
| 32 observers_.RemoveObserver(observer); |
| 33 } |
| 34 |
| 27 void FrameSinkManagerHost::CreateCompositorFrameSink( | 35 void FrameSinkManagerHost::CreateCompositorFrameSink( |
| 28 const cc::FrameSinkId& frame_sink_id, | 36 const cc::FrameSinkId& frame_sink_id, |
| 29 cc::mojom::MojoCompositorFrameSinkRequest request, | 37 cc::mojom::MojoCompositorFrameSinkRequest request, |
| 30 cc::mojom::MojoCompositorFrameSinkPrivateRequest private_request, | 38 cc::mojom::MojoCompositorFrameSinkPrivateRequest private_request, |
| 31 cc::mojom::MojoCompositorFrameSinkClientPtr client) { | 39 cc::mojom::MojoCompositorFrameSinkClientPtr client) { |
| 32 frame_sink_manager_ptr_->CreateCompositorFrameSink( | 40 frame_sink_manager_ptr_->CreateCompositorFrameSink( |
| 33 frame_sink_id, std::move(request), std::move(private_request), | 41 frame_sink_id, std::move(request), std::move(private_request), |
| 34 std::move(client)); | 42 std::move(client)); |
| 35 } | 43 } |
| 36 | 44 |
| 37 void FrameSinkManagerHost::RegisterFrameSinkHierarchy( | 45 void FrameSinkManagerHost::RegisterFrameSinkHierarchy( |
| 38 const cc::FrameSinkId& parent_frame_sink_id, | 46 const cc::FrameSinkId& parent_frame_sink_id, |
| 39 const cc::FrameSinkId& child_frame_sink_id) { | 47 const cc::FrameSinkId& child_frame_sink_id) { |
| 40 frame_sink_manager_ptr_->RegisterFrameSinkHierarchy(parent_frame_sink_id, | 48 frame_sink_manager_ptr_->RegisterFrameSinkHierarchy(parent_frame_sink_id, |
| 41 child_frame_sink_id); | 49 child_frame_sink_id); |
| 42 } | 50 } |
| 43 | 51 |
| 44 void FrameSinkManagerHost::UnregisterFrameSinkHierarchy( | 52 void FrameSinkManagerHost::UnregisterFrameSinkHierarchy( |
| 45 const cc::FrameSinkId& parent_frame_sink_id, | 53 const cc::FrameSinkId& parent_frame_sink_id, |
| 46 const cc::FrameSinkId& child_frame_sink_id) { | 54 const cc::FrameSinkId& child_frame_sink_id) { |
| 47 frame_sink_manager_ptr_->UnregisterFrameSinkHierarchy(parent_frame_sink_id, | 55 frame_sink_manager_ptr_->UnregisterFrameSinkHierarchy(parent_frame_sink_id, |
| 48 child_frame_sink_id); | 56 child_frame_sink_id); |
| 49 } | 57 } |
| 50 | 58 |
| 51 void FrameSinkManagerHost::OnSurfaceCreated( | 59 void FrameSinkManagerHost::OnSurfaceCreated( |
| 52 const cc::SurfaceInfo& surface_info) { | 60 const cc::SurfaceInfo& surface_info) { |
| 53 // TODO(kylechar): Implement. | 61 for (auto& observer : observers_) |
| 62 observer.OnSurfaceCreated(surface_info); |
| 54 } | 63 } |
| 55 | 64 |
| 56 } // namespace content | 65 } // namespace content |
| OLD | NEW |