| OLD | NEW |
| 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" |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 63 media::InitializeMediaLibrary(); | 63 media::InitializeMediaLibrary(); |
| 64 } | 64 } |
| 65 | 65 |
| 66 MediaFactory::~MediaFactory() { | 66 MediaFactory::~MediaFactory() { |
| 67 } | 67 } |
| 68 | 68 |
| 69 blink::WebMediaPlayer* MediaFactory::CreateMediaPlayer( | 69 blink::WebMediaPlayer* MediaFactory::CreateMediaPlayer( |
| 70 blink::WebLocalFrame* frame, | 70 blink::WebLocalFrame* frame, |
| 71 const blink::WebURL& url, | 71 const blink::WebURL& url, |
| 72 blink::WebMediaPlayerClient* client, | 72 blink::WebMediaPlayerClient* client, |
| 73 blink::WebMediaPlayerEncryptedMediaClient* encrypted_client, |
| 73 blink::WebContentDecryptionModule* initial_cdm, | 74 blink::WebContentDecryptionModule* initial_cdm, |
| 74 mojo::Shell* shell) { | 75 mojo::Shell* shell) { |
| 75 #if defined(OS_ANDROID) | 76 #if defined(OS_ANDROID) |
| 76 // TODO(xhwang): Get CreateMediaPlayer working on android. | 77 // TODO(xhwang): Get CreateMediaPlayer working on android. |
| 77 return nullptr; | 78 return nullptr; |
| 78 #else | 79 #else |
| 79 scoped_refptr<media::MediaLog> media_log(new media::MediaLog()); | 80 scoped_refptr<media::MediaLog> media_log(new media::MediaLog()); |
| 80 scoped_ptr<media::RendererFactory> media_renderer_factory; | 81 scoped_ptr<media::RendererFactory> media_renderer_factory; |
| 81 | 82 |
| 82 if (enable_mojo_media_renderer_) { | 83 if (enable_mojo_media_renderer_) { |
| 83 media_renderer_factory.reset( | 84 media_renderer_factory.reset( |
| 84 new media::MojoRendererFactory(GetMediaServiceProvider())); | 85 new media::MojoRendererFactory(GetMediaServiceProvider())); |
| 85 } else { | 86 } else { |
| 86 media_renderer_factory.reset( | 87 media_renderer_factory.reset( |
| 87 new media::DefaultRendererFactory(media_log, | 88 new media::DefaultRendererFactory(media_log, |
| 88 nullptr, // No GPU factory. | 89 nullptr, // No GPU factory. |
| 89 GetAudioHardwareConfig())); | 90 GetAudioHardwareConfig())); |
| 90 } | 91 } |
| 91 | 92 |
| 92 media::WebMediaPlayerParams params( | 93 media::WebMediaPlayerParams params( |
| 93 media::WebMediaPlayerParams::DeferLoadCB(), CreateAudioRendererSink(), | 94 media::WebMediaPlayerParams::DeferLoadCB(), CreateAudioRendererSink(), |
| 94 media_log, GetMediaThreadTaskRunner(), compositor_task_runner_, | 95 media_log, GetMediaThreadTaskRunner(), compositor_task_runner_, |
| 95 media::WebMediaPlayerParams::Context3DCB(), GetMediaPermission(), | 96 media::WebMediaPlayerParams::Context3DCB(), GetMediaPermission(), |
| 96 initial_cdm); | 97 initial_cdm); |
| 97 base::WeakPtr<media::WebMediaPlayerDelegate> delegate; | 98 base::WeakPtr<media::WebMediaPlayerDelegate> delegate; |
| 98 | 99 |
| 99 return new media::WebMediaPlayerImpl(frame, client, delegate, | 100 return new media::WebMediaPlayerImpl(frame, client, encrypted_client, |
| 100 media_renderer_factory.Pass(), | 101 delegate, media_renderer_factory.Pass(), |
| 101 GetCdmFactory(), params); | 102 GetCdmFactory(), params); |
| 102 #endif // defined(OS_ANDROID) | 103 #endif // defined(OS_ANDROID) |
| 103 } | 104 } |
| 104 | 105 |
| 105 blink::WebEncryptedMediaClient* MediaFactory::GetEncryptedMediaClient() { | 106 blink::WebEncryptedMediaClient* MediaFactory::GetEncryptedMediaClient() { |
| 106 if (!web_encrypted_media_client_) { | 107 if (!web_encrypted_media_client_) { |
| 107 web_encrypted_media_client_.reset(new media::WebEncryptedMediaClientImpl( | 108 web_encrypted_media_client_.reset(new media::WebEncryptedMediaClientImpl( |
| 108 base::Bind(&AreSecureCodecsSupported), GetCdmFactory(), | 109 base::Bind(&AreSecureCodecsSupported), GetCdmFactory(), |
| 109 GetMediaPermission())); | 110 GetMediaPermission())); |
| 110 } | 111 } |
| (...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 153 scoped_refptr<base::SingleThreadTaskRunner> | 154 scoped_refptr<base::SingleThreadTaskRunner> |
| 154 MediaFactory::GetMediaThreadTaskRunner() { | 155 MediaFactory::GetMediaThreadTaskRunner() { |
| 155 if (!media_thread_.IsRunning()) | 156 if (!media_thread_.IsRunning()) |
| 156 media_thread_.Start(); | 157 media_thread_.Start(); |
| 157 | 158 |
| 158 return media_thread_.task_runner(); | 159 return media_thread_.task_runner(); |
| 159 } | 160 } |
| 160 #endif // !defined(OS_ANDROID) | 161 #endif // !defined(OS_ANDROID) |
| 161 | 162 |
| 162 } // namespace html_viewer | 163 } // namespace html_viewer |
| OLD | NEW |