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

Unified Diff: chromecast/browser/cast_media_blocker.h

Issue 2453623003: Decouple MediaSession messages from WebContents (full patch) (Closed)
Patch Set: nit Created 4 years, 1 month 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: chromecast/browser/cast_media_blocker.h
diff --git a/chromecast/browser/cast_media_blocker.h b/chromecast/browser/cast_media_blocker.h
index b3350603f7b1fb448130768b7a7eb26cca37b899..1c3d562421799216447a49e1723d3efb8006c998 100644
--- a/chromecast/browser/cast_media_blocker.h
+++ b/chromecast/browser/cast_media_blocker.h
@@ -6,35 +6,29 @@
#define CHROMECAST_BROWSER_CAST_MEDIA_BLOCKER_H_
#include "base/macros.h"
-#include "base/callback_forward.h"
+#include "content/public/browser/media_session_observer.h"
#include "content/public/browser/web_contents_observer.h"
-namespace content {
-class WebContents;
-} // namespace content
-
namespace chromecast {
namespace shell {
// This class implements a blocking mode for web applications and is used in
// Chromecast internal code. Media is unblocked by default.
-class CastMediaBlocker : public content::WebContentsObserver {
+//
+// TODO(derekjchow): Remove the inheritance from WebContentsObserver.
+// See http://crbug.com/660331
+class CastMediaBlocker : public content::MediaSessionObserver,
+ content::WebContentsObserver {
public:
- explicit CastMediaBlocker(content::WebContents* web_contents);
-
- // Constructor for test. |suspend_cb| and |resume_cb| will be called when
- // Suspend() and Resume() are called.
- CastMediaBlocker(content::WebContents* web_contents,
- const base::Closure& suspend_cb,
- const base::Closure& resume_cb);
-
+ CastMediaBlocker(content::MediaSession* media_session,
+ content::WebContents* web_contents);
~CastMediaBlocker() override;
// Sets if the web contents is allowed to play media or not. If media is
// unblocked, previously suspended elements should begin playing again.
void BlockMediaLoading(bool blocked);
- // content::WebContentsObserver implementation:
+ // content::MediaSessionObserver implementation:
void MediaSessionStateChanged(bool is_controllable,
bool is_suspended) override;
@@ -50,9 +44,6 @@ class CastMediaBlocker : public content::WebContentsObserver {
void Suspend();
void Resume();
- base::Closure suspend_cb_;
- base::Closure resume_cb_;
-
// Whether or not media should be blocked. This value cache's the last call to
// BlockMediaLoading. Is false by default.
bool blocked_;

Powered by Google App Engine
This is Rietveld 408576698