| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/media_web_contents_observer_android.h" | 5 #include "content/browser/media/android/media_web_contents_observer_android.h" |
| 6 | 6 |
| 7 #include "content/browser/media/android/browser_media_player_manager.h" | 7 #include "content/browser/media/android/browser_media_player_manager.h" |
| 8 #include "content/browser/media/android/browser_media_session_manager.h" | 8 #include "content/browser/media/android/browser_media_session_manager.h" |
| 9 #include "content/browser/media/android/browser_surface_view_manager.h" |
| 9 #include "content/browser/media/android/media_session.h" | 10 #include "content/browser/media/android/media_session.h" |
| 10 #include "content/browser/media/android/media_session_controller.h" | 11 #include "content/browser/media/android/media_session_controller.h" |
| 11 #include "content/browser/media/android/media_session_observer.h" | 12 #include "content/browser/media/android/media_session_observer.h" |
| 12 #include "content/browser/media/cdm/browser_cdm_manager.h" | 13 #include "content/browser/media/cdm/browser_cdm_manager.h" |
| 13 #include "content/browser/web_contents/web_contents_impl.h" | 14 #include "content/browser/web_contents/web_contents_impl.h" |
| 14 #include "content/common/media/media_player_delegate_messages.h" | 15 #include "content/common/media/media_player_delegate_messages.h" |
| 15 #include "content/common/media/media_player_messages_android.h" | 16 #include "content/common/media/media_player_messages_android.h" |
| 16 #include "content/common/media/media_session_messages_android.h" | 17 #include "content/common/media/media_session_messages_android.h" |
| 18 #include "content/common/media/surface_view_manager_messages_android.h" |
| 17 #include "content/public/browser/render_frame_host.h" | 19 #include "content/public/browser/render_frame_host.h" |
| 18 #include "content/public/browser/web_contents.h" | 20 #include "content/public/browser/web_contents.h" |
| 19 #include "ipc/ipc_message_macros.h" | 21 #include "ipc/ipc_message_macros.h" |
| 20 #include "media/base/android/media_player_android.h" | 22 #include "media/base/android/media_player_android.h" |
| 21 | 23 |
| 22 namespace content { | 24 namespace content { |
| 23 | 25 |
| 24 MediaWebContentsObserverAndroid::MediaWebContentsObserverAndroid( | 26 MediaWebContentsObserverAndroid::MediaWebContentsObserverAndroid( |
| 25 WebContents* web_contents) | 27 WebContents* web_contents) |
| 26 : MediaWebContentsObserver(web_contents) {} | 28 : MediaWebContentsObserver(web_contents) {} |
| (...skipping 27 matching lines...) Expand all Loading... |
| 54 auto it = media_session_managers_.find(render_frame_host); | 56 auto it = media_session_managers_.find(render_frame_host); |
| 55 if (it != media_session_managers_.end()) | 57 if (it != media_session_managers_.end()) |
| 56 return it->second; | 58 return it->second; |
| 57 | 59 |
| 58 BrowserMediaSessionManager* manager = | 60 BrowserMediaSessionManager* manager = |
| 59 new BrowserMediaSessionManager(render_frame_host); | 61 new BrowserMediaSessionManager(render_frame_host); |
| 60 media_session_managers_.set(render_frame_host, make_scoped_ptr(manager)); | 62 media_session_managers_.set(render_frame_host, make_scoped_ptr(manager)); |
| 61 return manager; | 63 return manager; |
| 62 } | 64 } |
| 63 | 65 |
| 66 BrowserSurfaceViewManager* |
| 67 MediaWebContentsObserverAndroid::GetSurfaceViewManager( |
| 68 RenderFrameHost* render_frame_host) { |
| 69 auto it = surface_view_managers_.find(render_frame_host); |
| 70 if (it != surface_view_managers_.end()) |
| 71 return it->second; |
| 72 |
| 73 BrowserSurfaceViewManager* manager = |
| 74 new BrowserSurfaceViewManager(render_frame_host); |
| 75 surface_view_managers_.set(render_frame_host, make_scoped_ptr(manager)); |
| 76 return manager; |
| 77 } |
| 78 |
| 64 bool MediaWebContentsObserverAndroid::RequestPlay( | 79 bool MediaWebContentsObserverAndroid::RequestPlay( |
| 65 RenderFrameHost* render_frame_host, | 80 RenderFrameHost* render_frame_host, |
| 66 int delegate_id, | 81 int delegate_id, |
| 67 bool has_audio, | 82 bool has_audio, |
| 68 bool is_remote, | 83 bool is_remote, |
| 69 base::TimeDelta duration) { | 84 base::TimeDelta duration) { |
| 70 // |has_video| forced to true since the value doesn't matter at present. | 85 // |has_video| forced to true since the value doesn't matter at present. |
| 71 OnMediaPlaying(render_frame_host, delegate_id, true, has_audio, is_remote, | 86 OnMediaPlaying(render_frame_host, delegate_id, true, has_audio, is_remote, |
| 72 duration); | 87 duration); |
| 73 return media_session_map_.find(MediaPlayerId( | 88 return media_session_map_.find(MediaPlayerId( |
| (...skipping 17 matching lines...) Expand all Loading... |
| 91 if (it->first.first == render_frame_host) | 106 if (it->first.first == render_frame_host) |
| 92 it = media_session_map_.erase(it); | 107 it = media_session_map_.erase(it); |
| 93 else | 108 else |
| 94 ++it; | 109 ++it; |
| 95 } | 110 } |
| 96 | 111 |
| 97 // Always destroy the media players before CDMs because we do not support | 112 // Always destroy the media players before CDMs because we do not support |
| 98 // detaching CDMs from media players yet. See http://crbug.com/330324 | 113 // detaching CDMs from media players yet. See http://crbug.com/330324 |
| 99 media_player_managers_.erase(render_frame_host); | 114 media_player_managers_.erase(render_frame_host); |
| 100 media_session_managers_.erase(render_frame_host); | 115 media_session_managers_.erase(render_frame_host); |
| 116 surface_view_managers_.erase(render_frame_host); |
| 101 | 117 |
| 102 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager | 118 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager |
| 103 // and BrowserCdmManager all run on browser UI thread. So this call is okay. | 119 // and BrowserCdmManager all run on browser UI thread. So this call is okay. |
| 104 // In the future we need to support the case where MediaWebContentsObserver | 120 // In the future we need to support the case where MediaWebContentsObserver |
| 105 // get notified on browser UI thread, but BrowserMediaPlayerManager and | 121 // get notified on browser UI thread, but BrowserMediaPlayerManager and |
| 106 // BrowserCdmManager run on a different thread. | 122 // BrowserCdmManager run on a different thread. |
| 107 BrowserCdmManager* browser_cdm_manager = | 123 BrowserCdmManager* browser_cdm_manager = |
| 108 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID()); | 124 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID()); |
| 109 if (browser_cdm_manager) | 125 if (browser_cdm_manager) |
| 110 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID()); | 126 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID()); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 122 | 138 |
| 123 if (OnMediaPlayerMessageReceived(msg, render_frame_host)) | 139 if (OnMediaPlayerMessageReceived(msg, render_frame_host)) |
| 124 return true; | 140 return true; |
| 125 | 141 |
| 126 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host)) | 142 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host)) |
| 127 return true; | 143 return true; |
| 128 | 144 |
| 129 if (OnMediaSessionMessageReceived(msg, render_frame_host)) | 145 if (OnMediaSessionMessageReceived(msg, render_frame_host)) |
| 130 return true; | 146 return true; |
| 131 | 147 |
| 148 if (OnSurfaceViewManagerMessageReceived(msg, render_frame_host)) |
| 149 return true; |
| 150 |
| 132 return false; | 151 return false; |
| 133 } | 152 } |
| 134 | 153 |
| 135 void MediaWebContentsObserverAndroid::OnMediaPlayerDelegateMessageReceived( | 154 void MediaWebContentsObserverAndroid::OnMediaPlayerDelegateMessageReceived( |
| 136 const IPC::Message& msg, | 155 const IPC::Message& msg, |
| 137 RenderFrameHost* render_frame_host) { | 156 RenderFrameHost* render_frame_host) { |
| 138 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserverAndroid, msg, | 157 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserverAndroid, msg, |
| 139 render_frame_host) | 158 render_frame_host) |
| 140 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed, | 159 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed, |
| 141 OnMediaDestroyed) | 160 OnMediaDestroyed) |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 220 BrowserMediaSessionManager::OnDeactivate) | 239 BrowserMediaSessionManager::OnDeactivate) |
| 221 IPC_MESSAGE_FORWARD(MediaSessionHostMsg_SetMetadata, | 240 IPC_MESSAGE_FORWARD(MediaSessionHostMsg_SetMetadata, |
| 222 GetMediaSessionManager(render_frame_host), | 241 GetMediaSessionManager(render_frame_host), |
| 223 BrowserMediaSessionManager::OnSetMetadata) | 242 BrowserMediaSessionManager::OnSetMetadata) |
| 224 IPC_MESSAGE_UNHANDLED(handled = false) | 243 IPC_MESSAGE_UNHANDLED(handled = false) |
| 225 IPC_END_MESSAGE_MAP() | 244 IPC_END_MESSAGE_MAP() |
| 226 | 245 |
| 227 return handled; | 246 return handled; |
| 228 } | 247 } |
| 229 | 248 |
| 249 bool MediaWebContentsObserverAndroid::OnSurfaceViewManagerMessageReceived( |
| 250 const IPC::Message& msg, |
| 251 RenderFrameHost* render_frame_host) { |
| 252 bool handled = true; |
| 253 IPC_BEGIN_MESSAGE_MAP(MediaWebContentsObserverAndroid, msg) |
| 254 IPC_MESSAGE_FORWARD(BrowserSurfaceViewManagerMsg_CreateFullscreenSurface, |
| 255 GetSurfaceViewManager(render_frame_host), |
| 256 BrowserSurfaceViewManager::OnCreateFullscreenSurface) |
| 257 IPC_MESSAGE_FORWARD(BrowserSurfaceViewManagerMsg_FullscreenVideoSizeChanged, |
| 258 GetSurfaceViewManager(render_frame_host), |
| 259 BrowserSurfaceViewManager::OnFullscreenVideoSizeChanged) |
| 260 IPC_MESSAGE_UNHANDLED(handled = false) |
| 261 IPC_END_MESSAGE_MAP() |
| 262 return handled; |
| 263 } |
| 264 |
| 230 void MediaWebContentsObserverAndroid::OnSetCdm( | 265 void MediaWebContentsObserverAndroid::OnSetCdm( |
| 231 RenderFrameHost* render_frame_host, | 266 RenderFrameHost* render_frame_host, |
| 232 int player_id, | 267 int player_id, |
| 233 int cdm_id) { | 268 int cdm_id) { |
| 234 media::MediaPlayerAndroid* media_player = | 269 media::MediaPlayerAndroid* media_player = |
| 235 GetMediaPlayerManager(render_frame_host)->GetPlayer(player_id); | 270 GetMediaPlayerManager(render_frame_host)->GetPlayer(player_id); |
| 236 if (!media_player) { | 271 if (!media_player) { |
| 237 NOTREACHED() << "OnSetCdm: MediaPlayer not found for " << player_id; | 272 NOTREACHED() << "OnSetCdm: MediaPlayer not found for " << player_id; |
| 238 return; | 273 return; |
| 239 } | 274 } |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 307 scoped_ptr<MediaSessionController> controller( | 342 scoped_ptr<MediaSessionController> controller( |
| 308 new MediaSessionController(id, this)); | 343 new MediaSessionController(id, this)); |
| 309 | 344 |
| 310 if (!controller->Initialize(has_audio, is_remote, duration)) | 345 if (!controller->Initialize(has_audio, is_remote, duration)) |
| 311 return; | 346 return; |
| 312 | 347 |
| 313 media_session_map_[id] = std::move(controller); | 348 media_session_map_[id] = std::move(controller); |
| 314 } | 349 } |
| 315 | 350 |
| 316 } // namespace content | 351 } // namespace content |
| OLD | NEW |