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

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

Issue 2387293007: Register MediaPlayerRenderer service (Closed)
Patch Set: Addressed comments 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
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 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
OLDNEW
« media/blink/webmediaplayer_impl.cc ('K') | « media/mojo/clients/mojo_renderer.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698