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

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

Issue 975943003: Revert of Revert of Propagate audible state from player to the containing tab" (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 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/browser_media_player_manager.h
diff --git a/content/browser/media/android/browser_media_player_manager.h b/content/browser/media/android/browser_media_player_manager.h
index e0a40132bea994a8a825ce5050ea353b488f3675..bec469510d968215033bfe2d7864257647b1c536 100644
--- a/content/browser/media/android/browser_media_player_manager.h
+++ b/content/browser/media/android/browser_media_player_manager.h
@@ -30,6 +30,7 @@ namespace content {
class BrowserDemuxerAndroid;
class ContentViewCoreImpl;
class ExternalVideoSurfaceContainer;
+class MediaPlayersObserver;
class RenderFrameHost;
class WebContents;
@@ -42,7 +43,8 @@ class CONTENT_EXPORT BrowserMediaPlayerManager
: public media::MediaPlayerManager {
public:
// Permits embedders to provide an extended version of the class.
- typedef BrowserMediaPlayerManager* (*Factory)(RenderFrameHost*);
+ typedef BrowserMediaPlayerManager* (*Factory)(RenderFrameHost*,
+ MediaPlayersObserver*);
static void RegisterFactory(Factory factory);
// Permits embedders to handle custom urls.
@@ -50,7 +52,9 @@ class CONTENT_EXPORT BrowserMediaPlayerManager
media::MediaUrlInterceptor* media_url_interceptor);
// Returns a new instance using the registered factory if available.
- static BrowserMediaPlayerManager* Create(RenderFrameHost* rfh);
+ static BrowserMediaPlayerManager* Create(
+ RenderFrameHost* rfh,
+ MediaPlayersObserver* audio_monitor);
ContentViewCoreImpl* GetContentViewCore() const;
@@ -83,6 +87,9 @@ class CONTENT_EXPORT BrowserMediaPlayerManager
const base::TimeDelta& current_time) override;
void OnError(int player_id, int error) override;
void OnVideoSizeChanged(int player_id, int width, int height) override;
+ void OnAudibleStateChanged(
+ int player_id, bool is_audible_now) override;
+
media::MediaResourceGetter* GetMediaResourceGetter() override;
media::MediaUrlInterceptor* GetMediaUrlInterceptor() override;
media::MediaPlayerAndroid* GetFullscreenPlayer() override;
@@ -118,7 +125,8 @@ class CONTENT_EXPORT BrowserMediaPlayerManager
protected:
// Clients must use Create() or subclass constructor.
- explicit BrowserMediaPlayerManager(RenderFrameHost* render_frame_host);
+ BrowserMediaPlayerManager(RenderFrameHost* render_frame_host,
+ MediaPlayersObserver* audio_monitor);
WebContents* web_contents() const { return web_contents_; }
@@ -168,6 +176,8 @@ class CONTENT_EXPORT BrowserMediaPlayerManager
RenderFrameHost* const render_frame_host_;
+ MediaPlayersObserver* audio_monitor_;
+
// An array of managed players.
ScopedVector<media::MediaPlayerAndroid> players_;

Powered by Google App Engine
This is Rietveld 408576698