Index: content/browser/media/media_web_contents_observer.cc |
diff --git a/content/browser/media/media_web_contents_observer.cc b/content/browser/media/media_web_contents_observer.cc |
index 67ef0368680e8d6be542d65dd5b9f43a857ffd01..5be0006c306bfe06e5cb893c1fc9c9323b06c29f 100644 |
--- a/content/browser/media/media_web_contents_observer.cc |
+++ b/content/browser/media/media_web_contents_observer.cc |
@@ -11,7 +11,7 @@ |
#include "content/browser/media/audio_stream_monitor.h" |
#include "content/browser/power_save_blocker_impl.h" |
#include "content/browser/web_contents/web_contents_impl.h" |
-#include "content/common/frame_messages.h" |
+#include "content/common/media/media_player_delegate_messages.h" |
#include "content/public/browser/render_frame_host.h" |
#include "content/public/browser/web_contents.h" |
#include "ipc/ipc_message_macros.h" |
@@ -64,28 +64,49 @@ bool MediaWebContentsObserver::OnMessageReceived( |
// TODO(dalecurtis): These should no longer be FrameHostMsg. |
IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MediaWebContentsObserver, msg, |
render_frame_host) |
- IPC_MESSAGE_HANDLER(FrameHostMsg_MediaPlayingNotification, |
- OnMediaPlayingNotification) |
- IPC_MESSAGE_HANDLER(FrameHostMsg_MediaPausedNotification, |
- OnMediaPausedNotification) |
+ IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaDestroyed, |
+ OnMediaDestroyed) |
+ IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaPlaying, |
+ OnMediaPlaying) |
+ IPC_MESSAGE_HANDLER(MediaPlayerDelegateHostMsg_OnMediaPaused, OnMediaPaused) |
IPC_MESSAGE_UNHANDLED(handled = false) |
IPC_END_MESSAGE_MAP() |
return handled; |
} |
-void MediaWebContentsObserver::OnMediaPlayingNotification( |
+void MediaWebContentsObserver::WasShown() { |
+ // Restore power save blocker if there are active video players running. |
+ if (!active_video_players_.empty() && !video_power_save_blocker_) |
+ CreateVideoPowerSaveBlocker(); |
+} |
+ |
+void MediaWebContentsObserver::WasHidden() { |
+ // If there are entities capturing screenshots or video (e.g., mirroring), |
+ // don't release the power save blocker. |
+ if (!web_contents()->GetCapturerCount()) |
+ video_power_save_blocker_.reset(); |
+} |
+ |
+void MediaWebContentsObserver::OnMediaDestroyed( |
+ RenderFrameHost* render_frame_host, |
+ int delegate_id) { |
+ OnMediaPaused(render_frame_host, delegate_id, true); |
+} |
+ |
+void MediaWebContentsObserver::OnMediaPlaying( |
RenderFrameHost* render_frame_host, |
- int64_t player_cookie, |
+ int delegate_id, |
bool has_video, |
bool has_audio, |
- bool is_remote) { |
+ bool is_remote, |
+ base::TimeDelta duration) { |
// Ignore the videos playing remotely and don't hold the wake lock for the |
// screen. TODO(dalecurtis): Is this correct? It means observers will not |
// receive play and pause messages. |
if (is_remote) |
return; |
- const MediaPlayerId id(render_frame_host, player_cookie); |
+ const MediaPlayerId id(render_frame_host, delegate_id); |
if (has_audio) { |
AddMediaPlayerEntry(id, &active_audio_players_); |
@@ -112,10 +133,10 @@ void MediaWebContentsObserver::OnMediaPlayingNotification( |
static_cast<WebContentsImpl*>(web_contents())->MediaStartedPlaying(id); |
} |
-void MediaWebContentsObserver::OnMediaPausedNotification( |
- RenderFrameHost* render_frame_host, |
- int64_t player_cookie) { |
- const MediaPlayerId id(render_frame_host, player_cookie); |
+void MediaWebContentsObserver::OnMediaPaused(RenderFrameHost* render_frame_host, |
+ int delegate_id, |
+ bool reached_end_of_stream) { |
+ const MediaPlayerId id(render_frame_host, delegate_id); |
const bool removed_audio = RemoveMediaPlayerEntry(id, &active_audio_players_); |
const bool removed_video = RemoveMediaPlayerEntry(id, &active_video_players_); |
MaybeReleasePowerSaveBlockers(); |
@@ -161,19 +182,6 @@ void MediaWebContentsObserver::CreateVideoPowerSaveBlocker() { |
#endif |
} |
-void MediaWebContentsObserver::WasShown() { |
- // Restore power save blocker if there are active video players running. |
- if (!active_video_players_.empty() && !video_power_save_blocker_) |
- CreateVideoPowerSaveBlocker(); |
-} |
- |
-void MediaWebContentsObserver::WasHidden() { |
- // If there are entities capturing screenshots or video (e.g., mirroring), |
- // don't release the power save blocker. |
- if (!web_contents()->GetCapturerCount()) |
- video_power_save_blocker_.reset(); |
-} |
- |
void MediaWebContentsObserver::MaybeReleasePowerSaveBlockers() { |
// If there are no more audio players and we don't have audio stream |
// monitoring, release the audio power save blocker here instead of during |
@@ -226,8 +234,8 @@ void MediaWebContentsObserver::RemoveAllMediaPlayerEntries( |
if (it == player_map->end()) |
return; |
- for (int64_t player_cookie : it->second) |
- removed_players->insert(MediaPlayerId(render_frame_host, player_cookie)); |
+ for (int delegate_id : it->second) |
+ removed_players->insert(MediaPlayerId(render_frame_host, delegate_id)); |
player_map->erase(it); |
} |