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

Unified Diff: content/browser/media/android/media_web_contents_observer_android.h

Issue 1655083002: Enable SurfaceView fullscreen video on Android with WebMediaPlayerImpl (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@avda-sv
Patch Set: Add an empty destructor to satisfy chromium-style Created 4 years, 10 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 side-by-side diff with in-line comments
Download patch
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 63b17da873f232ab8f30a11b9b7017cd14d18d3c..e8e36503f8f13655680957bdcf4fabce67237369 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 BrowserSurfaceViewManager;
class MediaSessionController;
// This class adds Android specific extensions to the MediaWebContentsObserver.
@@ -31,13 +32,15 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid
static MediaWebContentsObserverAndroid* FromWebContents(
WebContents* web_contents);
- // Gets the media player or media session manager associated with the given
- // |render_frame_host| respectively. Creates a new one if it doesn't exist.
- // The caller doesn't own the returned pointer.
+ // Gets one of the managers associated with the given |render_frame_host|.
+ // Creates a new one if it doesn't exist. The caller doesn't own the
+ // returned pointer.
BrowserMediaPlayerManager* GetMediaPlayerManager(
RenderFrameHost* render_frame_host);
BrowserMediaSessionManager* GetMediaSessionManager(
RenderFrameHost* render_frame_host);
+ BrowserSurfaceViewManager* GetSurfaceViewManager(
+ RenderFrameHost* render_frame_host);
// Called by the WebContents when a tab has been closed but may still be
// available for "undo" -- indicates that all media players (even audio only
@@ -59,7 +62,7 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid
void OnFrameInfoUpdated();
#endif // defined(VIDEO_HOLE)
- // MediaWebContentsObserverAndroid overrides.
+ // MediaWebContentsObserver overrides.
void RenderFrameDeleted(RenderFrameHost* render_frame_host) override;
bool OnMessageReceived(const IPC::Message& message,
RenderFrameHost* render_frame_host) override;
@@ -91,6 +94,9 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid
bool OnMediaSessionMessageReceived(const IPC::Message& message,
RenderFrameHost* render_frame_host);
+ bool OnSurfaceViewManagerMessageReceived(const IPC::Message& message,
+ RenderFrameHost* render_frame_host);
+
void OnSetCdm(RenderFrameHost* render_frame_host, int player_id, int cdm_id);
// Map from RenderFrameHost* to BrowserMediaPlayerManager.
@@ -110,6 +116,11 @@ class CONTENT_EXPORT MediaWebContentsObserverAndroid
std::map<MediaPlayerId, scoped_ptr<MediaSessionController>>;
MediaSessionMap media_session_map_;
+ using SurfaceViewManagerMap =
+ base::ScopedPtrHashMap<RenderFrameHost*,
+ scoped_ptr<BrowserSurfaceViewManager>>;
+ SurfaceViewManagerMap surface_view_managers_;
+
DISALLOW_COPY_AND_ASSIGN(MediaWebContentsObserverAndroid);
};

Powered by Google App Engine
This is Rietveld 408576698