| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "media/mojo/clients/mojo_renderer_factory.h" | 5 #include "media/mojo/clients/mojo_renderer_factory.h" |
| 6 | 6 |
| 7 #include "base/single_thread_task_runner.h" | 7 #include "base/single_thread_task_runner.h" |
| 8 #include "media/mojo/clients/mojo_renderer.h" | 8 #include "media/mojo/clients/mojo_renderer.h" |
| 9 #include "media/renderers/video_overlay_factory.h" | 9 #include "media/renderers/video_overlay_factory.h" |
| 10 #include "services/shell/public/cpp/connect.h" | 10 #include "services/shell/public/cpp/connect.h" |
| 11 #include "services/shell/public/interfaces/interface_provider.mojom.h" | 11 #include "services/shell/public/interfaces/interface_provider.mojom.h" |
| 12 | 12 |
| 13 namespace media { | 13 namespace media { |
| 14 | 14 |
| 15 MojoRendererFactory::MojoRendererFactory( | 15 MojoRendererFactory::MojoRendererFactory( |
| 16 const GetGpuFactoriesCB& get_gpu_factories_cb, | 16 const GetGpuFactoriesCB& get_gpu_factories_cb, |
| 17 shell::mojom::InterfaceProvider* interface_provider) | 17 shell::mojom::InterfaceProvider* interface_provider) |
| 18 : get_gpu_factories_cb_(get_gpu_factories_cb), | 18 : get_gpu_factories_cb_(get_gpu_factories_cb), |
| 19 interface_provider_(interface_provider) { | 19 interface_provider_(interface_provider) { |
| 20 DCHECK(!get_gpu_factories_cb_.is_null()); | |
| 21 DCHECK(interface_provider_); | 20 DCHECK(interface_provider_); |
| 22 } | 21 } |
| 23 | 22 |
| 24 MojoRendererFactory::~MojoRendererFactory() {} | 23 MojoRendererFactory::~MojoRendererFactory() {} |
| 25 | 24 |
| 26 std::unique_ptr<Renderer> MojoRendererFactory::CreateRenderer( | 25 std::unique_ptr<Renderer> MojoRendererFactory::CreateRenderer( |
| 27 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, | 26 const scoped_refptr<base::SingleThreadTaskRunner>& media_task_runner, |
| 28 const scoped_refptr<base::TaskRunner>& /* worker_task_runner */, | 27 const scoped_refptr<base::TaskRunner>& /* worker_task_runner */, |
| 29 AudioRendererSink* /* audio_renderer_sink */, | 28 AudioRendererSink* /* audio_renderer_sink */, |
| 30 VideoRendererSink* video_renderer_sink, | 29 VideoRendererSink* video_renderer_sink, |
| 31 const RequestSurfaceCB& /* request_surface_cb */) { | 30 const RequestSurfaceCB& /* request_surface_cb */) { |
| 32 std::unique_ptr<VideoOverlayFactory> overlay_factory( | 31 std::unique_ptr<VideoOverlayFactory> overlay_factory; |
| 33 new VideoOverlayFactory(get_gpu_factories_cb_.Run())); | 32 |
| 33 if (!get_gpu_factories_cb_.is_null()) { |
| 34 overlay_factory = |
| 35 base::MakeUnique<VideoOverlayFactory>(get_gpu_factories_cb_.Run()); |
| 36 } |
| 34 | 37 |
| 35 mojom::RendererPtr renderer_ptr; | 38 mojom::RendererPtr renderer_ptr; |
| 36 shell::GetInterface<mojom::Renderer>(interface_provider_, &renderer_ptr); | 39 shell::GetInterface<mojom::Renderer>(interface_provider_, &renderer_ptr); |
| 37 | 40 |
| 38 return std::unique_ptr<Renderer>( | 41 return std::unique_ptr<Renderer>( |
| 39 new MojoRenderer(media_task_runner, std::move(overlay_factory), | 42 new MojoRenderer(media_task_runner, std::move(overlay_factory), |
| 40 video_renderer_sink, std::move(renderer_ptr))); | 43 video_renderer_sink, std::move(renderer_ptr))); |
| 41 } | 44 } |
| 42 | 45 |
| 43 } // namespace media | 46 } // namespace media |
| OLD | NEW |