| 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 static void SuspendAllMediaPlayersInRenderFrame( | 26 static void SuspendAllMediaPlayersInRenderFrame( |
| 25 RenderFrameHost* render_frame_host) { | 27 RenderFrameHost* render_frame_host) { |
| 26 render_frame_host->Send(new MediaPlayerDelegateMsg_SuspendAllMediaPlayers( | 28 render_frame_host->Send(new MediaPlayerDelegateMsg_SuspendAllMediaPlayers( |
| (...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 60 auto it = media_session_managers_.find(render_frame_host); | 62 auto it = media_session_managers_.find(render_frame_host); |
| 61 if (it != media_session_managers_.end()) | 63 if (it != media_session_managers_.end()) |
| 62 return it->second; | 64 return it->second; |
| 63 | 65 |
| 64 BrowserMediaSessionManager* manager = | 66 BrowserMediaSessionManager* manager = |
| 65 new BrowserMediaSessionManager(render_frame_host); | 67 new BrowserMediaSessionManager(render_frame_host); |
| 66 media_session_managers_.set(render_frame_host, make_scoped_ptr(manager)); | 68 media_session_managers_.set(render_frame_host, make_scoped_ptr(manager)); |
| 67 return manager; | 69 return manager; |
| 68 } | 70 } |
| 69 | 71 |
| 72 BrowserSurfaceViewManager* |
| 73 MediaWebContentsObserverAndroid::GetSurfaceViewManager( |
| 74 RenderFrameHost* render_frame_host) { |
| 75 auto it = surface_view_managers_.find(render_frame_host); |
| 76 if (it != surface_view_managers_.end()) |
| 77 return it->second; |
| 78 |
| 79 BrowserSurfaceViewManager* manager = |
| 80 new BrowserSurfaceViewManager(render_frame_host); |
| 81 surface_view_managers_.set(render_frame_host, make_scoped_ptr(manager)); |
| 82 return manager; |
| 83 } |
| 84 |
| 70 void MediaWebContentsObserverAndroid::SuspendAllMediaPlayers() { | 85 void MediaWebContentsObserverAndroid::SuspendAllMediaPlayers() { |
| 71 web_contents()->ForEachFrame( | 86 web_contents()->ForEachFrame( |
| 72 base::Bind(&SuspendAllMediaPlayersInRenderFrame)); | 87 base::Bind(&SuspendAllMediaPlayersInRenderFrame)); |
| 73 } | 88 } |
| 74 | 89 |
| 75 bool MediaWebContentsObserverAndroid::RequestPlay( | 90 bool MediaWebContentsObserverAndroid::RequestPlay( |
| 76 RenderFrameHost* render_frame_host, | 91 RenderFrameHost* render_frame_host, |
| 77 int delegate_id, | 92 int delegate_id, |
| 78 bool has_audio, | 93 bool has_audio, |
| 79 bool is_remote, | 94 bool is_remote, |
| (...skipping 22 matching lines...) Expand all Loading... |
| 102 if (it->first.first == render_frame_host) | 117 if (it->first.first == render_frame_host) |
| 103 it = media_session_map_.erase(it); | 118 it = media_session_map_.erase(it); |
| 104 else | 119 else |
| 105 ++it; | 120 ++it; |
| 106 } | 121 } |
| 107 | 122 |
| 108 // Always destroy the media players before CDMs because we do not support | 123 // Always destroy the media players before CDMs because we do not support |
| 109 // detaching CDMs from media players yet. See http://crbug.com/330324 | 124 // detaching CDMs from media players yet. See http://crbug.com/330324 |
| 110 media_player_managers_.erase(render_frame_host); | 125 media_player_managers_.erase(render_frame_host); |
| 111 media_session_managers_.erase(render_frame_host); | 126 media_session_managers_.erase(render_frame_host); |
| 127 surface_view_managers_.erase(render_frame_host); |
| 112 | 128 |
| 113 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager | 129 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager |
| 114 // and BrowserCdmManager all run on browser UI thread. So this call is okay. | 130 // and BrowserCdmManager all run on browser UI thread. So this call is okay. |
| 115 // In the future we need to support the case where MediaWebContentsObserver | 131 // In the future we need to support the case where MediaWebContentsObserver |
| 116 // get notified on browser UI thread, but BrowserMediaPlayerManager and | 132 // get notified on browser UI thread, but BrowserMediaPlayerManager and |
| 117 // BrowserCdmManager run on a different thread. | 133 // BrowserCdmManager run on a different thread. |
| 118 BrowserCdmManager* browser_cdm_manager = | 134 BrowserCdmManager* browser_cdm_manager = |
| 119 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID()); | 135 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID()); |
| 120 if (browser_cdm_manager) | 136 if (browser_cdm_manager) |
| 121 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID()); | 137 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID()); |
| (...skipping 11 matching lines...) Expand all Loading... |
| 133 | 149 |
| 134 if (OnMediaPlayerMessageReceived(msg, render_frame_host)) | 150 if (OnMediaPlayerMessageReceived(msg, render_frame_host)) |
| 135 return true; | 151 return true; |
| 136 | 152 |
| 137 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host)) | 153 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host)) |
| 138 return true; | 154 return true; |
| 139 | 155 |
| 140 if (OnMediaSessionMessageReceived(msg, render_frame_host)) | 156 if (OnMediaSessionMessageReceived(msg, render_frame_host)) |
| 141 return true; | 157 return true; |
| 142 | 158 |
| 159 if (OnSurfaceViewManagerMessageReceived(msg, render_frame_host)) |
| 160 return true; |
| 161 |
| 143 return false; | 162 return false; |
| 144 } | 163 } |
| 145 | 164 |
| 146 void MediaWebContentsObserverAndroid::OnMediaPlayerDelegateMessageReceived( | 165 void MediaWebContentsObserverAndroid::OnMediaPlayerDelegateMessageReceived( |
| 147 const IPC::Message& msg, | 166 const IPC::Message& msg, |
| 148 RenderFrameHost* render_frame_host) { | 167 RenderFrameHost* render_frame_host) { |
| 149 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserverAndroid, msg, | 168 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserverAndroid, msg, |
| 150 render_frame_host) | 169 render_frame_host) |
| 151 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed, | 170 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed, |
| 152 OnMediaDestroyed) | 171 OnMediaDestroyed) |
| (...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 231 BrowserMediaSessionManager::OnDeactivate) | 250 BrowserMediaSessionManager::OnDeactivate) |
| 232 IPC_MESSAGE_FORWARD(MediaSessionHostMsg_SetMetadata, | 251 IPC_MESSAGE_FORWARD(MediaSessionHostMsg_SetMetadata, |
| 233 GetMediaSessionManager(render_frame_host), | 252 GetMediaSessionManager(render_frame_host), |
| 234 BrowserMediaSessionManager::OnSetMetadata) | 253 BrowserMediaSessionManager::OnSetMetadata) |
| 235 IPC_MESSAGE_UNHANDLED(handled = false) | 254 IPC_MESSAGE_UNHANDLED(handled = false) |
| 236 IPC_END_MESSAGE_MAP() | 255 IPC_END_MESSAGE_MAP() |
| 237 | 256 |
| 238 return handled; | 257 return handled; |
| 239 } | 258 } |
| 240 | 259 |
| 260 bool MediaWebContentsObserverAndroid::OnSurfaceViewManagerMessageReceived( |
| 261 const IPC::Message& msg, |
| 262 RenderFrameHost* render_frame_host) { |
| 263 bool handled = true; |
| 264 IPC_BEGIN_MESSAGE_MAP(MediaWebContentsObserverAndroid, msg) |
| 265 IPC_MESSAGE_FORWARD(SurfaceViewManagerHostMsg_CreateFullscreenSurface, |
| 266 GetSurfaceViewManager(render_frame_host), |
| 267 BrowserSurfaceViewManager::OnCreateFullscreenSurface) |
| 268 IPC_MESSAGE_FORWARD(SurfaceViewManagerHostMsg_NaturalSizeChanged, |
| 269 GetSurfaceViewManager(render_frame_host), |
| 270 BrowserSurfaceViewManager::OnNaturalSizeChanged) |
| 271 IPC_MESSAGE_UNHANDLED(handled = false) |
| 272 IPC_END_MESSAGE_MAP() |
| 273 return handled; |
| 274 } |
| 275 |
| 241 void MediaWebContentsObserverAndroid::OnSetCdm( | 276 void MediaWebContentsObserverAndroid::OnSetCdm( |
| 242 RenderFrameHost* render_frame_host, | 277 RenderFrameHost* render_frame_host, |
| 243 int player_id, | 278 int player_id, |
| 244 int cdm_id) { | 279 int cdm_id) { |
| 245 media::MediaPlayerAndroid* media_player = | 280 media::MediaPlayerAndroid* media_player = |
| 246 GetMediaPlayerManager(render_frame_host)->GetPlayer(player_id); | 281 GetMediaPlayerManager(render_frame_host)->GetPlayer(player_id); |
| 247 if (!media_player) { | 282 if (!media_player) { |
| 248 NOTREACHED() << "OnSetCdm: MediaPlayer not found for " << player_id; | 283 NOTREACHED() << "OnSetCdm: MediaPlayer not found for " << player_id; |
| 249 return; | 284 return; |
| 250 } | 285 } |
| (...skipping 67 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 318 scoped_ptr<MediaSessionController> controller( | 353 scoped_ptr<MediaSessionController> controller( |
| 319 new MediaSessionController(id, this)); | 354 new MediaSessionController(id, this)); |
| 320 | 355 |
| 321 if (!controller->Initialize(has_audio, is_remote, duration)) | 356 if (!controller->Initialize(has_audio, is_remote, duration)) |
| 322 return; | 357 return; |
| 323 | 358 |
| 324 media_session_map_[id] = std::move(controller); | 359 media_session_map_[id] = std::move(controller); |
| 325 } | 360 } |
| 326 | 361 |
| 327 } // namespace content | 362 } // namespace content |
| OLD | NEW |