Chromium Code Reviews| Index: mojo/services/html_viewer/webmediaplayer_factory.cc |
| diff --git a/mojo/services/html_viewer/webmediaplayer_factory.cc b/mojo/services/html_viewer/webmediaplayer_factory.cc |
| index 98b4dc06db6a2f8dd1a62c388a7056909be8b1f1..42ae027561564a732b97e54278afe93059f3523b 100644 |
| --- a/mojo/services/html_viewer/webmediaplayer_factory.cc |
| +++ b/mojo/services/html_viewer/webmediaplayer_factory.cc |
| @@ -19,7 +19,9 @@ |
| #include "media/cdm/default_cdm_factory.h" |
| #include "media/filters/default_renderer_factory.h" |
| #include "media/filters/gpu_video_accelerator_factories.h" |
| +#include "media/mojo/interfaces/content_decryption_module_factory.mojom.h" |
| #include "media/mojo/interfaces/media_renderer.mojom.h" |
| +#include "media/mojo/services/mojo_cdm_factory.h" |
| #include "media/mojo/services/mojo_renderer_factory.h" |
| #include "mojo/public/cpp/application/connect.h" |
| #include "mojo/public/interfaces/application/shell.mojom.h" |
| @@ -85,18 +87,26 @@ blink::WebMediaPlayer* WebMediaPlayerFactory::CreateMediaPlayer( |
| #else |
| scoped_refptr<media::MediaLog> media_log(new media::MediaLog()); |
| scoped_ptr<media::RendererFactory> media_renderer_factory; |
| + scoped_ptr<media::CdmFactory> cdm_factory; |
| if (enable_mojo_media_renderer_) { |
| - ServiceProviderPtr media_renderer_service_provider; |
| + ServiceProviderPtr media_service_provider; |
| shell->ConnectToApplication("mojo:media", |
| - GetProxy(&media_renderer_service_provider)); |
| + GetProxy(&media_service_provider)); |
| + |
| + // TODO(xhwang): Create only one |cdm_factory_ptr| per process. |
| + mojo::ContentDecryptionModuleFactoryPtr cdm_factory_ptr; |
| + mojo::ConnectToService(media_service_provider.get(), &cdm_factory_ptr); |
| + cdm_factory.reset(new media::MojoCdmFactory(cdm_factory_ptr.Pass())); |
|
xhwang
2015/01/05 23:52:38
Background for another CL (https://codereview.chro
|
| + |
| media_renderer_factory.reset(new media::MojoRendererFactory(make_scoped_ptr( |
| - new RendererServiceProvider(media_renderer_service_provider.Pass())))); |
| + new RendererServiceProvider(media_service_provider.Pass())))); |
| } else { |
| media_renderer_factory.reset( |
| new media::DefaultRendererFactory(media_log, |
| nullptr, // No GPU factory. |
| GetAudioHardwareConfig())); |
| + cdm_factory.reset(new media::DefaultCdmFactory()); |
| } |
| media::WebMediaPlayerParams params(media::WebMediaPlayerParams::DeferLoadCB(), |
| @@ -105,8 +115,6 @@ blink::WebMediaPlayer* WebMediaPlayerFactory::CreateMediaPlayer( |
| compositor_task_runner_, initial_cdm); |
| base::WeakPtr<media::WebMediaPlayerDelegate> delegate; |
| - scoped_ptr<media::CdmFactory> cdm_factory(new media::DefaultCdmFactory()); |
| - |
| return new media::WebMediaPlayerImpl(frame, client, delegate, |
| media_renderer_factory.Pass(), |
| cdm_factory.Pass(), params); |