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

Side by Side Diff: components/html_viewer/media_factory.cc

Issue 1230313010: media: Add ServiceFactory mojo interface and implementation. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase only Created 5 years, 5 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 | « components/html_viewer/media_factory.h ('k') | content/renderer/render_frame_impl.h » ('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 "components/html_viewer/media_factory.h" 5 #include "components/html_viewer/media_factory.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/files/file_path.h" 9 #include "base/files/file_path.h"
10 #include "base/path_service.h" 10 #include "base/path_service.h"
11 #include "base/threading/thread.h" 11 #include "base/threading/thread.h"
12 #include "build/build_config.h" 12 #include "build/build_config.h"
13 #include "media/audio/audio_manager.h" 13 #include "media/audio/audio_manager.h"
14 #include "media/audio/audio_manager_base.h" 14 #include "media/audio/audio_manager_base.h"
15 #include "media/audio/audio_output_stream_sink.h" 15 #include "media/audio/audio_output_stream_sink.h"
16 #include "media/base/audio_hardware_config.h" 16 #include "media/base/audio_hardware_config.h"
17 #include "media/base/media.h" 17 #include "media/base/media.h"
18 #include "media/base/media_log.h" 18 #include "media/base/media_log.h"
19 #include "media/blink/webencryptedmediaclient_impl.h" 19 #include "media/blink/webencryptedmediaclient_impl.h"
20 #include "media/blink/webmediaplayer_impl.h" 20 #include "media/blink/webmediaplayer_impl.h"
21 #include "media/blink/webmediaplayer_params.h" 21 #include "media/blink/webmediaplayer_params.h"
22 #include "media/cdm/default_cdm_factory.h" 22 #include "media/cdm/default_cdm_factory.h"
23 #include "media/filters/default_media_permission.h" 23 #include "media/filters/default_media_permission.h"
24 #include "media/mojo/interfaces/media_renderer.mojom.h" 24 #include "media/mojo/interfaces/media_renderer.mojom.h"
25 #include "media/mojo/services/mojo_cdm_factory.h" 25 #include "media/mojo/services/mojo_cdm_factory.h"
26 #include "media/mojo/services/mojo_renderer_factory.h" 26 #include "media/mojo/services/mojo_renderer_factory.h"
27 #include "media/renderers/default_renderer_factory.h" 27 #include "media/renderers/default_renderer_factory.h"
28 #include "media/renderers/gpu_video_accelerator_factories.h" 28 #include "media/renderers/gpu_video_accelerator_factories.h"
29 #include "mojo/application/public/cpp/connect.h"
29 #include "mojo/application/public/interfaces/shell.mojom.h" 30 #include "mojo/application/public/interfaces/shell.mojom.h"
30 31
31 namespace html_viewer { 32 namespace html_viewer {
32 33
33 namespace { 34 namespace {
34 35
35 // Enable MediaRenderer in media pipeline instead of using the internal 36 // Enable MediaRenderer in media pipeline instead of using the internal
36 // media::Renderer implementation. 37 // media::Renderer implementation.
37 // TODO(xhwang): Move this to media_switches.h. 38 // TODO(xhwang): Move this to media_switches.h.
38 const char kEnableMojoMediaRenderer[] = "enable-mojo-media-renderer"; 39 const char kEnableMojoMediaRenderer[] = "enable-mojo-media-renderer";
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after
76 mojo::Shell* shell) { 77 mojo::Shell* shell) {
77 #if defined(OS_ANDROID) 78 #if defined(OS_ANDROID)
78 // TODO(xhwang): Get CreateMediaPlayer working on android. 79 // TODO(xhwang): Get CreateMediaPlayer working on android.
79 return nullptr; 80 return nullptr;
80 #else 81 #else
81 scoped_refptr<media::MediaLog> media_log(new media::MediaLog()); 82 scoped_refptr<media::MediaLog> media_log(new media::MediaLog());
82 scoped_ptr<media::RendererFactory> media_renderer_factory; 83 scoped_ptr<media::RendererFactory> media_renderer_factory;
83 84
84 if (enable_mojo_media_renderer_) { 85 if (enable_mojo_media_renderer_) {
85 media_renderer_factory.reset( 86 media_renderer_factory.reset(
86 new media::MojoRendererFactory(GetMediaServiceProvider())); 87 new media::MojoRendererFactory(GetMediaServiceFactory()));
87 } else { 88 } else {
88 media_renderer_factory.reset( 89 media_renderer_factory.reset(
89 new media::DefaultRendererFactory(media_log, 90 new media::DefaultRendererFactory(media_log,
90 nullptr, // No GPU factory. 91 nullptr, // No GPU factory.
91 GetAudioHardwareConfig())); 92 GetAudioHardwareConfig()));
92 } 93 }
93 94
94 media::WebMediaPlayerParams params( 95 media::WebMediaPlayerParams params(
95 media::WebMediaPlayerParams::DeferLoadCB(), CreateAudioRendererSink(), 96 media::WebMediaPlayerParams::DeferLoadCB(), CreateAudioRendererSink(),
96 media_log, GetMediaThreadTaskRunner(), compositor_task_runner_, 97 media_log, GetMediaThreadTaskRunner(), compositor_task_runner_,
97 media::WebMediaPlayerParams::Context3DCB(), GetMediaPermission(), 98 media::WebMediaPlayerParams::Context3DCB(), GetMediaPermission(),
98 initial_cdm); 99 initial_cdm);
99 base::WeakPtr<media::WebMediaPlayerDelegate> delegate; 100 base::WeakPtr<media::WebMediaPlayerDelegate> delegate;
100 101
101 return new media::WebMediaPlayerImpl(frame, client, encrypted_client, 102 return new media::WebMediaPlayerImpl(frame, client, encrypted_client,
102 delegate, media_renderer_factory.Pass(), 103 delegate, media_renderer_factory.Pass(),
103 GetCdmFactory(), params); 104 GetCdmFactory(), params);
104 #endif // defined(OS_ANDROID) 105 #endif // defined(OS_ANDROID)
105 } 106 }
106 107
107 blink::WebEncryptedMediaClient* MediaFactory::GetEncryptedMediaClient() { 108 blink::WebEncryptedMediaClient* MediaFactory::GetEncryptedMediaClient() {
108 if (!web_encrypted_media_client_) { 109 if (!web_encrypted_media_client_) {
109 web_encrypted_media_client_.reset(new media::WebEncryptedMediaClientImpl( 110 web_encrypted_media_client_.reset(new media::WebEncryptedMediaClientImpl(
110 base::Bind(&AreSecureCodecsSupported), GetCdmFactory(), 111 base::Bind(&AreSecureCodecsSupported), GetCdmFactory(),
111 GetMediaPermission())); 112 GetMediaPermission()));
112 } 113 }
113 return web_encrypted_media_client_.get(); 114 return web_encrypted_media_client_.get();
114 } 115 }
115 116
116 mojo::ServiceProvider* MediaFactory::GetMediaServiceProvider() { 117 media::interfaces::ServiceFactory* MediaFactory::GetMediaServiceFactory() {
117 if (!media_service_provider_) { 118 if (!media_service_factory_) {
119 mojo::ServiceProviderPtr service_provider;
118 mojo::URLRequestPtr request(mojo::URLRequest::New()); 120 mojo::URLRequestPtr request(mojo::URLRequest::New());
119 request->url = mojo::String::From("mojo:media"); 121 request->url = mojo::String::From("mojo:media");
120 shell_->ConnectToApplication(request.Pass(), 122 shell_->ConnectToApplication(request.Pass(), GetProxy(&service_provider),
121 GetProxy(&media_service_provider_), nullptr); 123 nullptr);
124 mojo::ConnectToService(service_provider.get(), &media_service_factory_);
122 } 125 }
123 126
124 return media_service_provider_.get(); 127 return media_service_factory_.get();
125 } 128 }
126 129
127 media::MediaPermission* MediaFactory::GetMediaPermission() { 130 media::MediaPermission* MediaFactory::GetMediaPermission() {
128 // TODO(xhwang): Replace DefaultMediaPermission with something real when 131 // TODO(xhwang): Replace DefaultMediaPermission with something real when
129 // permissions are supported in html_viewer. 132 // permissions are supported in html_viewer.
130 NOTIMPLEMENTED(); 133 NOTIMPLEMENTED();
131 134
132 if (!media_permission_) 135 if (!media_permission_)
133 media_permission_.reset(new media::DefaultMediaPermission(true)); 136 media_permission_.reset(new media::DefaultMediaPermission(true));
134 return media_permission_.get(); 137 return media_permission_.get();
135 } 138 }
136 139
137 media::CdmFactory* MediaFactory::GetCdmFactory() { 140 media::CdmFactory* MediaFactory::GetCdmFactory() {
138 if (!cdm_factory_) { 141 if (!cdm_factory_) {
139 if (enable_mojo_media_renderer_) 142 if (enable_mojo_media_renderer_)
140 cdm_factory_.reset(new media::MojoCdmFactory(GetMediaServiceProvider())); 143 cdm_factory_.reset(new media::MojoCdmFactory(GetMediaServiceFactory()));
141 else 144 else
142 cdm_factory_.reset(new media::DefaultCdmFactory()); 145 cdm_factory_.reset(new media::DefaultCdmFactory());
143 } 146 }
144 147
145 return cdm_factory_.get(); 148 return cdm_factory_.get();
146 } 149 }
147 150
148 #if !defined(OS_ANDROID) 151 #if !defined(OS_ANDROID)
149 const media::AudioHardwareConfig& MediaFactory::GetAudioHardwareConfig() { 152 const media::AudioHardwareConfig& MediaFactory::GetAudioHardwareConfig() {
150 return audio_hardware_config_; 153 return audio_hardware_config_;
151 } 154 }
152 155
153 scoped_refptr<media::AudioRendererSink> 156 scoped_refptr<media::AudioRendererSink>
154 MediaFactory::CreateAudioRendererSink() { 157 MediaFactory::CreateAudioRendererSink() {
155 // TODO(dalecurtis): Replace this with an interface to an actual mojo service; 158 // TODO(dalecurtis): Replace this with an interface to an actual mojo service;
156 // the AudioOutputStreamSink will not work in sandboxed processes. 159 // the AudioOutputStreamSink will not work in sandboxed processes.
157 return new media::AudioOutputStreamSink(); 160 return new media::AudioOutputStreamSink();
158 } 161 }
159 162
160 scoped_refptr<base::SingleThreadTaskRunner> 163 scoped_refptr<base::SingleThreadTaskRunner>
161 MediaFactory::GetMediaThreadTaskRunner() { 164 MediaFactory::GetMediaThreadTaskRunner() {
162 if (!media_thread_.IsRunning()) 165 if (!media_thread_.IsRunning())
163 media_thread_.Start(); 166 media_thread_.Start();
164 167
165 return media_thread_.task_runner(); 168 return media_thread_.task_runner();
166 } 169 }
167 #endif // !defined(OS_ANDROID) 170 #endif // !defined(OS_ANDROID)
168 171
169 } // namespace html_viewer 172 } // namespace html_viewer
OLDNEW
« no previous file with comments | « components/html_viewer/media_factory.h ('k') | content/renderer/render_frame_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698