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

Side by Side Diff: content/browser/media/android/media_web_contents_observer_android.cc

Issue 1698933004: Make MediaSession a runtime-enabled feature on Desktop. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase Created 4 years, 9 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
OLDNEW
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/browser_surface_view_manager.h"
10 #include "content/browser/media/android/media_session.h"
11 #include "content/browser/media/android/media_session_controller.h"
12 #include "content/browser/media/android/media_session_observer.h"
13 #include "content/browser/media/cdm/browser_cdm_manager.h" 10 #include "content/browser/media/cdm/browser_cdm_manager.h"
14 #include "content/browser/web_contents/web_contents_impl.h" 11 #include "content/browser/web_contents/web_contents_impl.h"
15 #include "content/common/media/media_player_delegate_messages.h" 12 #include "content/common/media/media_player_delegate_messages.h"
16 #include "content/common/media/media_player_messages_android.h" 13 #include "content/common/media/media_player_messages_android.h"
17 #include "content/common/media/media_session_messages_android.h" 14 #include "content/common/media/media_session_messages_android.h"
18 #include "content/common/media/surface_view_manager_messages_android.h" 15 #include "content/common/media/surface_view_manager_messages_android.h"
19 #include "content/public/browser/render_frame_host.h" 16 #include "content/public/browser/render_frame_host.h"
20 #include "content/public/browser/web_contents.h" 17 #include "content/public/browser/web_contents.h"
21 #include "ipc/ipc_message_macros.h" 18 #include "ipc/ipc_message_macros.h"
22 #include "media/base/android/media_player_android.h" 19 #include "media/base/android/media_player_android.h"
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
86 web_contents()->ForEachFrame( 83 web_contents()->ForEachFrame(
87 base::Bind(&SuspendAllMediaPlayersInRenderFrame)); 84 base::Bind(&SuspendAllMediaPlayersInRenderFrame));
88 } 85 }
89 86
90 bool MediaWebContentsObserverAndroid::RequestPlay( 87 bool MediaWebContentsObserverAndroid::RequestPlay(
91 RenderFrameHost* render_frame_host, 88 RenderFrameHost* render_frame_host,
92 int delegate_id, 89 int delegate_id,
93 bool has_audio, 90 bool has_audio,
94 bool is_remote, 91 bool is_remote,
95 base::TimeDelta duration) { 92 base::TimeDelta duration) {
96 // |has_video| forced to true since the value doesn't matter at present. 93 return session_controllers_manager()->RequestPlay(
97 OnMediaPlaying(render_frame_host, delegate_id, true, has_audio, is_remote, 94 MediaPlayerId(render_frame_host, delegate_id),
98 duration); 95 has_audio, is_remote, duration);
99 return media_session_map_.find(MediaPlayerId(
100 render_frame_host, delegate_id)) != media_session_map_.end();
101 } 96 }
102 97
103 #if defined(VIDEO_HOLE) 98 #if defined(VIDEO_HOLE)
104 void MediaWebContentsObserverAndroid::OnFrameInfoUpdated() { 99 void MediaWebContentsObserverAndroid::OnFrameInfoUpdated() {
105 for (auto it = media_player_managers_.begin(); 100 for (auto it = media_player_managers_.begin();
106 it != media_player_managers_.end(); ++it) { 101 it != media_player_managers_.end(); ++it) {
107 it->second->OnFrameInfoUpdated(); 102 it->second->OnFrameInfoUpdated();
108 } 103 }
109 } 104 }
110 #endif // defined(VIDEO_HOLE) 105 #endif // defined(VIDEO_HOLE)
111 106
112 void MediaWebContentsObserverAndroid::RenderFrameDeleted( 107 void MediaWebContentsObserverAndroid::RenderFrameDeleted(
113 RenderFrameHost* render_frame_host) { 108 RenderFrameHost* render_frame_host) {
114 MediaWebContentsObserver::RenderFrameDeleted(render_frame_host); 109 MediaWebContentsObserver::RenderFrameDeleted(render_frame_host);
115 110
116 for (auto it = media_session_map_.begin(); it != media_session_map_.end();) {
117 if (it->first.first == render_frame_host)
118 it = media_session_map_.erase(it);
119 else
120 ++it;
121 }
122
123 // Always destroy the media players before CDMs because we do not support 111 // Always destroy the media players before CDMs because we do not support
124 // detaching CDMs from media players yet. See http://crbug.com/330324 112 // detaching CDMs from media players yet. See http://crbug.com/330324
125 media_player_managers_.erase(render_frame_host); 113 media_player_managers_.erase(render_frame_host);
126 media_session_managers_.erase(render_frame_host); 114 media_session_managers_.erase(render_frame_host);
127 surface_view_managers_.erase(render_frame_host); 115 surface_view_managers_.erase(render_frame_host);
128 116
129 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager 117 // TODO(xhwang): Currently MediaWebContentsObserver, BrowserMediaPlayerManager
130 // and BrowserCdmManager all run on browser UI thread. So this call is okay. 118 // and BrowserCdmManager all run on browser UI thread. So this call is okay.
131 // In the future we need to support the case where MediaWebContentsObserver 119 // In the future we need to support the case where MediaWebContentsObserver
132 // get notified on browser UI thread, but BrowserMediaPlayerManager and 120 // get notified on browser UI thread, but BrowserMediaPlayerManager and
133 // BrowserCdmManager run on a different thread. 121 // BrowserCdmManager run on a different thread.
134 BrowserCdmManager* browser_cdm_manager = 122 BrowserCdmManager* browser_cdm_manager =
135 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID()); 123 BrowserCdmManager::FromProcess(render_frame_host->GetProcess()->GetID());
136 if (browser_cdm_manager) 124 if (browser_cdm_manager)
137 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID()); 125 browser_cdm_manager->RenderFrameDeleted(render_frame_host->GetRoutingID());
138 } 126 }
139 127
140 bool MediaWebContentsObserverAndroid::OnMessageReceived( 128 bool MediaWebContentsObserverAndroid::OnMessageReceived(
141 const IPC::Message& msg, 129 const IPC::Message& msg,
142 RenderFrameHost* render_frame_host) { 130 RenderFrameHost* render_frame_host) {
143 // Receive play/pause/destroyed messages, but don't mark as processed so they
144 // are also handled by MediaWebContentsObserver.
145 OnMediaPlayerDelegateMessageReceived(msg, render_frame_host);
146
147 if (MediaWebContentsObserver::OnMessageReceived(msg, render_frame_host)) 131 if (MediaWebContentsObserver::OnMessageReceived(msg, render_frame_host))
148 return true; 132 return true;
149 133
150 if (OnMediaPlayerMessageReceived(msg, render_frame_host)) 134 if (OnMediaPlayerMessageReceived(msg, render_frame_host))
151 return true; 135 return true;
152 136
153 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host)) 137 if (OnMediaPlayerSetCdmMessageReceived(msg, render_frame_host))
154 return true; 138 return true;
155 139
156 if (OnMediaSessionMessageReceived(msg, render_frame_host)) 140 if (OnMediaSessionMessageReceived(msg, render_frame_host))
157 return true; 141 return true;
158 142
159 if (OnSurfaceViewManagerMessageReceived(msg, render_frame_host)) 143 if (OnSurfaceViewManagerMessageReceived(msg, render_frame_host))
160 return true; 144 return true;
161 145
162 return false; 146 return false;
163 } 147 }
164 148
165 void MediaWebContentsObserverAndroid::OnMediaPlayerDelegateMessageReceived(
166 const IPC::Message& msg,
167 RenderFrameHost* render_frame_host) {
168 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserverAndroid, msg,
169 render_frame_host)
170 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed,
171 OnMediaDestroyed)
172 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaPaused, OnMediaPaused)
173 IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaPlaying,
174 OnMediaPlaying)
175 IPC_END_MESSAGE_MAP()
176 }
177
178 bool MediaWebContentsObserverAndroid::OnMediaPlayerMessageReceived( 149 bool MediaWebContentsObserverAndroid::OnMediaPlayerMessageReceived(
179 const IPC::Message& msg, 150 const IPC::Message& msg,
180 RenderFrameHost* render_frame_host) { 151 RenderFrameHost* render_frame_host) {
181 bool handled = true; 152 bool handled = true;
182 IPC_BEGIN_MESSAGE_MAP(MediaWebContentsObserverAndroid, msg) 153 IPC_BEGIN_MESSAGE_MAP(MediaWebContentsObserverAndroid, msg)
183 IPC_MESSAGE_FORWARD(MediaPlayerHostMsg_EnterFullscreen, 154 IPC_MESSAGE_FORWARD(MediaPlayerHostMsg_EnterFullscreen,
184 GetMediaPlayerManager(render_frame_host), 155 GetMediaPlayerManager(render_frame_host),
185 BrowserMediaPlayerManager::OnEnterFullscreen) 156 BrowserMediaPlayerManager::OnEnterFullscreen)
186 IPC_MESSAGE_FORWARD(MediaPlayerHostMsg_Initialize, 157 IPC_MESSAGE_FORWARD(MediaPlayerHostMsg_Initialize,
187 GetMediaPlayerManager(render_frame_host), 158 GetMediaPlayerManager(render_frame_host),
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after
297 if (!cdm) { 268 if (!cdm) {
298 NOTREACHED() << "OnSetCdm: CDM not found for " << cdm_id; 269 NOTREACHED() << "OnSetCdm: CDM not found for " << cdm_id;
299 return; 270 return;
300 } 271 }
301 272
302 // TODO(xhwang): This could possibly fail. In that case we should reject the 273 // TODO(xhwang): This could possibly fail. In that case we should reject the
303 // promise. 274 // promise.
304 media_player->SetCdm(cdm); 275 media_player->SetCdm(cdm);
305 } 276 }
306 277
307 void MediaWebContentsObserverAndroid::OnMediaDestroyed(
308 RenderFrameHost* render_frame_host,
309 int delegate_id) {
310 media_session_map_.erase(MediaPlayerId(render_frame_host, delegate_id));
311 }
312
313 void MediaWebContentsObserverAndroid::OnMediaPaused(
314 RenderFrameHost* render_frame_host,
315 int delegate_id,
316 bool reached_end_of_stream) {
317 // Drop the session if playback completes normally.
318 if (reached_end_of_stream) {
319 OnMediaDestroyed(render_frame_host, delegate_id);
320 return;
321 }
322
323 auto it =
324 media_session_map_.find(MediaPlayerId(render_frame_host, delegate_id));
325 if (it == media_session_map_.end())
326 return;
327
328 it->second->OnPlaybackPaused();
329 }
330
331 void MediaWebContentsObserverAndroid::OnMediaPlaying(
332 RenderFrameHost* render_frame_host,
333 int delegate_id,
334 bool has_video,
335 bool has_audio,
336 bool is_remote,
337 base::TimeDelta duration) {
338 const MediaPlayerId id(render_frame_host, delegate_id);
339
340 // Since we don't remove session instances on pause, there may be an existing
341 // instance for this playback attempt.
342 //
343 // In this case, try to reinitialize it with the new settings. If they are
344 // the same, this is a no-op. If the reinitialize fails, destroy the
345 // controller. A later playback attempt will create a new controller.
346 auto it = media_session_map_.find(id);
347 if (it != media_session_map_.end()) {
348 if (!it->second->Initialize(has_audio, is_remote, duration))
349 media_session_map_.erase(it);
350 return;
351 }
352
353 scoped_ptr<MediaSessionController> controller(
354 new MediaSessionController(id, this));
355
356 if (!controller->Initialize(has_audio, is_remote, duration))
357 return;
358
359 media_session_map_[id] = std::move(controller);
360 }
361
362 } // namespace content 278 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698