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

Unified Diff: mojo/services/html_viewer/webmediaplayer_factory.cc

Issue 840473002: media: Support creation and SetCdm() for mojo based CDM. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 11 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 side-by-side diff with in-line comments
Download patch
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);
« media/mojo/services/mojo_media_application.cc ('K') | « media/mojo/services/mojo_renderer_service.cc ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698