OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/media/android/browser_media_player_manager.h" | 5 #include "content/browser/media/android/browser_media_player_manager.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/android/scoped_java_ref.h" | 9 #include "base/android/scoped_java_ref.h" |
10 #include "base/memory/singleton.h" | 10 #include "base/memory/singleton.h" |
(...skipping 11 matching lines...) Expand all Loading... |
22 #include "content/public/browser/content_browser_client.h" | 22 #include "content/public/browser/content_browser_client.h" |
23 #include "content/public/browser/render_frame_host.h" | 23 #include "content/public/browser/render_frame_host.h" |
24 #include "content/public/browser/render_process_host.h" | 24 #include "content/public/browser/render_process_host.h" |
25 #include "content/public/browser/render_view_host.h" | 25 #include "content/public/browser/render_view_host.h" |
26 #include "content/public/browser/storage_partition.h" | 26 #include "content/public/browser/storage_partition.h" |
27 #include "content/public/browser/web_contents.h" | 27 #include "content/public/browser/web_contents.h" |
28 #include "content/public/browser/web_contents_delegate.h" | 28 #include "content/public/browser/web_contents_delegate.h" |
29 #include "content/public/common/content_client.h" | 29 #include "content/public/common/content_client.h" |
30 #include "content/public/common/content_switches.h" | 30 #include "content/public/common/content_switches.h" |
31 #include "gpu/ipc/common/android/surface_texture_peer.h" | 31 #include "gpu/ipc/common/android/surface_texture_peer.h" |
32 #include "media/base/android/media_codec_player.h" | |
33 #include "media/base/android/media_player_bridge.h" | 32 #include "media/base/android/media_player_bridge.h" |
34 #include "media/base/android/media_source_player.h" | 33 #include "media/base/android/media_source_player.h" |
35 #include "media/base/android/media_task_runner.h" | |
36 #include "media/base/android/media_url_interceptor.h" | 34 #include "media/base/android/media_url_interceptor.h" |
37 | 35 |
38 #if !defined(USE_AURA) | 36 #if !defined(USE_AURA) |
39 #include "content/browser/android/content_view_core_impl.h" | 37 #include "content/browser/android/content_view_core_impl.h" |
40 #include "content/browser/renderer_host/render_widget_host_view_android.h" | 38 #include "content/browser/renderer_host/render_widget_host_view_android.h" |
41 #endif | 39 #endif |
42 | 40 |
43 using media::MediaCodecPlayer; | |
44 using media::MediaPlayerAndroid; | 41 using media::MediaPlayerAndroid; |
45 using media::MediaPlayerBridge; | 42 using media::MediaPlayerBridge; |
46 using media::MediaPlayerManager; | 43 using media::MediaPlayerManager; |
47 using media::MediaSourcePlayer; | 44 using media::MediaSourcePlayer; |
48 | 45 |
49 namespace content { | 46 namespace content { |
50 | 47 |
51 namespace { | 48 namespace { |
52 | 49 |
53 class BrowserSurfaceTexturePeer : public gpu::SurfaceTexturePeer { | 50 class BrowserSurfaceTexturePeer : public gpu::SurfaceTexturePeer { |
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
235 // the page. | 232 // the page. |
236 OnMediaMetadataChanged(media_player_params.player_id, base::TimeDelta(), | 233 OnMediaMetadataChanged(media_player_params.player_id, base::TimeDelta(), |
237 0, 0, false); | 234 0, 0, false); |
238 } else if (!should_block) { | 235 } else if (!should_block) { |
239 media_player_bridge->Initialize(); | 236 media_player_bridge->Initialize(); |
240 } | 237 } |
241 return media_player_bridge; | 238 return media_player_bridge; |
242 } | 239 } |
243 | 240 |
244 case MEDIA_PLAYER_TYPE_MEDIA_SOURCE: { | 241 case MEDIA_PLAYER_TYPE_MEDIA_SOURCE: { |
245 if (media::UseMediaThreadForMediaPlayback()) { | 242 return new MediaSourcePlayer( |
246 return new MediaCodecPlayer( | 243 media_player_params.player_id, this, |
247 media_player_params.player_id, weak_ptr_factory_.GetWeakPtr(), | 244 base::Bind(&BrowserMediaPlayerManager::OnDecoderResourcesReleased, |
248 base::Bind(&BrowserMediaPlayerManager::OnDecoderResourcesReleased, | 245 weak_ptr_factory_.GetWeakPtr()), |
249 weak_ptr_factory_.GetWeakPtr()), | 246 demuxer->CreateDemuxer(media_player_params.demuxer_client_id), |
250 demuxer->CreateDemuxer(media_player_params.demuxer_client_id), | 247 media_player_params.frame_url, media_player_params.media_session_id); |
251 media_player_params.frame_url, | |
252 media_player_params.media_session_id); | |
253 } else { | |
254 return new MediaSourcePlayer( | |
255 media_player_params.player_id, this, | |
256 base::Bind(&BrowserMediaPlayerManager::OnDecoderResourcesReleased, | |
257 weak_ptr_factory_.GetWeakPtr()), | |
258 demuxer->CreateDemuxer(media_player_params.demuxer_client_id), | |
259 media_player_params.frame_url, | |
260 media_player_params.media_session_id); | |
261 } | |
262 } | 248 } |
263 } | 249 } |
264 | 250 |
265 NOTREACHED(); | 251 NOTREACHED(); |
266 return NULL; | 252 return NULL; |
267 } | 253 } |
268 | 254 |
269 BrowserMediaPlayerManager::BrowserMediaPlayerManager( | 255 BrowserMediaPlayerManager::BrowserMediaPlayerManager( |
270 RenderFrameHost* render_frame_host) | 256 RenderFrameHost* render_frame_host) |
271 : render_frame_host_(render_frame_host), | 257 : render_frame_host_(render_frame_host), |
(...skipping 535 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
807 if (!player) | 793 if (!player) |
808 return; | 794 return; |
809 player->Start(); | 795 player->Start(); |
810 if (fullscreen_player_id_ == player_id && fullscreen_player_is_released_) { | 796 if (fullscreen_player_id_ == player_id && fullscreen_player_is_released_) { |
811 video_view_->OpenVideo(); | 797 video_view_->OpenVideo(); |
812 fullscreen_player_is_released_ = false; | 798 fullscreen_player_is_released_ = false; |
813 } | 799 } |
814 } | 800 } |
815 | 801 |
816 } // namespace content | 802 } // namespace content |
OLD | NEW |