Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(39)

Side by Side Diff: media/mojo/clients/mojo_renderer_factory.cc

Issue 2387293007: Register MediaPlayerRenderer service (Closed)
Patch Set: Typo. Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « media/mojo/clients/mojo_renderer.cc ('k') | media/remoting/remoting_controller.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 // |get_gpu_factories_cb_| can be null in the HLS/MediaPlayerRenderer case,
34 // when we do not need to create video overlays.
35 if (!get_gpu_factories_cb_.is_null()) {
36 overlay_factory =
37 base::MakeUnique<VideoOverlayFactory>(get_gpu_factories_cb_.Run());
38 }
34 39
35 mojom::RendererPtr renderer_ptr; 40 mojom::RendererPtr renderer_ptr;
36 shell::GetInterface<mojom::Renderer>(interface_provider_, &renderer_ptr); 41 shell::GetInterface<mojom::Renderer>(interface_provider_, &renderer_ptr);
37 42
38 return std::unique_ptr<Renderer>( 43 return std::unique_ptr<Renderer>(
39 new MojoRenderer(media_task_runner, std::move(overlay_factory), 44 new MojoRenderer(media_task_runner, std::move(overlay_factory),
40 video_renderer_sink, std::move(renderer_ptr))); 45 video_renderer_sink, std::move(renderer_ptr)));
41 } 46 }
42 47
43 } // namespace media 48 } // namespace media
OLDNEW
« no previous file with comments | « media/mojo/clients/mojo_renderer.cc ('k') | media/remoting/remoting_controller.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698