| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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 "services/ui/ws/gpu_compositor_frame_sink.h" | 5 #include "services/ui/ws/gpu_compositor_frame_sink.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
| 9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
| 10 #include "base/threading/thread_task_runner_handle.h" | 10 #include "base/threading/thread_task_runner_handle.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 namespace ui { | 26 namespace ui { |
| 27 namespace ws { | 27 namespace ws { |
| 28 | 28 |
| 29 GpuCompositorFrameSink::GpuCompositorFrameSink( | 29 GpuCompositorFrameSink::GpuCompositorFrameSink( |
| 30 scoped_refptr<DisplayCompositor> display_compositor, | 30 scoped_refptr<DisplayCompositor> display_compositor, |
| 31 const cc::FrameSinkId& frame_sink_id, | 31 const cc::FrameSinkId& frame_sink_id, |
| 32 gfx::AcceleratedWidget widget, | 32 gfx::AcceleratedWidget widget, |
| 33 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, | 33 gpu::GpuMemoryBufferManager* gpu_memory_buffer_manager, |
| 34 scoped_refptr<SurfacesContextProvider> context_provider, | 34 scoped_refptr<SurfacesContextProvider> context_provider, |
| 35 cc::mojom::MojoCompositorFrameSinkRequest request, | 35 cc::mojom::MojoCompositorFrameSinkRequest request, |
| 36 cc::mojom::MojoCompositorFrameSinkPrivateRequest private_request, |
| 36 cc::mojom::MojoCompositorFrameSinkClientPtr client) | 37 cc::mojom::MojoCompositorFrameSinkClientPtr client) |
| 37 : frame_sink_id_(frame_sink_id), | 38 : frame_sink_id_(frame_sink_id), |
| 38 task_runner_(base::ThreadTaskRunnerHandle::Get()), | 39 task_runner_(base::ThreadTaskRunnerHandle::Get()), |
| 39 display_compositor_(display_compositor), | 40 display_compositor_(display_compositor), |
| 40 surface_factory_(frame_sink_id_, display_compositor_->manager(), this), | 41 surface_factory_(frame_sink_id_, display_compositor_->manager(), this), |
| 41 client_(std::move(client)), | 42 client_(std::move(client)), |
| 42 binding_(this, std::move(request)) { | 43 binding_(this, std::move(request)), |
| 44 private_binding_(this, std::move(private_request)) { |
| 43 display_compositor_->manager()->RegisterFrameSinkId(frame_sink_id_); | 45 display_compositor_->manager()->RegisterFrameSinkId(frame_sink_id_); |
| 44 display_compositor_->manager()->RegisterSurfaceFactoryClient(frame_sink_id_, | 46 display_compositor_->manager()->RegisterSurfaceFactoryClient(frame_sink_id_, |
| 45 this); | 47 this); |
| 46 | 48 |
| 47 if (widget != gfx::kNullAcceleratedWidget) | 49 if (widget != gfx::kNullAcceleratedWidget) |
| 48 InitDisplay(widget, gpu_memory_buffer_manager, std::move(context_provider)); | 50 InitDisplay(widget, gpu_memory_buffer_manager, std::move(context_provider)); |
| 49 } | 51 } |
| 50 | 52 |
| 51 GpuCompositorFrameSink::~GpuCompositorFrameSink() { | 53 GpuCompositorFrameSink::~GpuCompositorFrameSink() { |
| 52 // SurfaceFactory's destructor will attempt to return resources which will | 54 // SurfaceFactory's destructor will attempt to return resources which will |
| (...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 212 | 214 |
| 213 added_frame_observer_ = needs_begin_frame_; | 215 added_frame_observer_ = needs_begin_frame_; |
| 214 if (needs_begin_frame_) | 216 if (needs_begin_frame_) |
| 215 begin_frame_source_->AddObserver(this); | 217 begin_frame_source_->AddObserver(this); |
| 216 else | 218 else |
| 217 begin_frame_source_->RemoveObserver(this); | 219 begin_frame_source_->RemoveObserver(this); |
| 218 } | 220 } |
| 219 | 221 |
| 220 } // namespace ws | 222 } // namespace ws |
| 221 } // namespace ui | 223 } // namespace ui |
| OLD | NEW |