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()) { | |
xhwang
2016/10/12 20:14:15
Please add a comment when this could be null.
tguilbert
2016/10/12 21:46:25
Done.
| |
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 |