Index: content/browser/media/android/media_web_contents_observer_android.h |
diff --git a/content/browser/media/android/media_web_contents_observer_android.h b/content/browser/media/android/media_web_contents_observer_android.h |
index a95e1615fb695922fbdc7bfd8d250eeccd997bf1..9397a33504a21f4cff34b4dc33352c8446f576c8 100644 |
--- a/content/browser/media/android/media_web_contents_observer_android.h |
+++ b/content/browser/media/android/media_web_contents_observer_android.h |
@@ -18,6 +18,7 @@ namespace content { |
class BrowserCdmManager; |
class BrowserMediaPlayerManager; |
class BrowserMediaSessionManager; |
+class MediaSessionController; |
// This class adds Android specific extensions to the MediaWebContentsObserver. |
class CONTENT_EXPORT MediaWebContentsObserverAndroid |
@@ -38,6 +39,16 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid |
BrowserMediaSessionManager* GetMediaSessionManager( |
RenderFrameHost* render_frame_host); |
+ // Initiates a synchronous MediaSession request for browser side players. |
+ // |
+ // TODO(dalecurtis): Delete this method once we're no longer using WMPA and |
+ // the BrowserMediaPlayerManagers. |
mlamouri (slow - plz ping)
2016/01/22 16:58:31
You reference multiple time this TODO. Maybe you s
DaleCurtis
2016/01/23 02:11:00
Done.
|
+ bool RequestPlay(RenderFrameHost* render_frame_host, |
+ int64_t player_cookie, |
+ bool has_audio, |
+ bool is_remote, |
+ base::TimeDelta duration); |
+ |
#if defined(VIDEO_HOLE) |
void OnFrameInfoUpdated(); |
#endif // defined(VIDEO_HOLE) |
@@ -48,6 +59,22 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid |
RenderFrameHost* render_frame_host) override; |
private: |
+ // Handles messages for the media player delegate; does not modify the handled |
nasko
2016/01/22 17:28:32
nit: Is "media player delegate" a type? If yes, wh
DaleCurtis
2016/01/23 02:11:00
Done.
|
+ // state since the superclass needs to handle these as well. |
+ void OnMediaPlayerDelegateMessageReceived(const IPC::Message& msg, |
+ RenderFrameHost* render_frame_host); |
+ void OnMediaDestroyedNotification(RenderFrameHost* render_frame_host, |
+ int64_t player_cookie); |
+ void OnMediaPlayingNotification(RenderFrameHost* render_frame_host, |
+ int64_t player_cookie, |
+ bool has_video, |
+ bool has_audio, |
+ bool is_remote, |
+ base::TimeDelta duration); |
+ void OnMediaPausedNotification(RenderFrameHost* render_frame_host, |
+ int64_t player_cookie, |
+ bool reached_end_of_stream); |
+ |
// Helper functions to handle media player IPC messages. Returns whether the |
// |message| is handled in the function. |
bool OnMediaPlayerMessageReceived(const IPC::Message& message, |
@@ -70,6 +97,11 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid |
scoped_ptr<BrowserMediaSessionManager>>; |
MediaSessionManagerMap media_session_managers_; |
+ // Map of renderer side media players to session controllers. |
nasko
2016/01/22 17:28:32
nit: s/renderer side/renderer process/
DaleCurtis
2016/01/23 02:11:00
Done.
|
+ using MediaSessionMap = |
+ std::map<MediaPlayerId, scoped_ptr<MediaSessionController>>; |
+ MediaSessionMap media_session_map_; |
+ |
DISALLOW_COPY_AND_ASSIGN(MediaWebContentsObserverAndroid); |
}; |