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

Unified Diff: third_party/WebKit/Source/modules/mediasession/MediaSession.h

Issue 2428523002: Add media controls to MediaSession in Blink (Closed)
Patch Set: rebased Created 4 years, 2 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: third_party/WebKit/Source/modules/mediasession/MediaSession.h
diff --git a/third_party/WebKit/Source/modules/mediasession/MediaSession.h b/third_party/WebKit/Source/modules/mediasession/MediaSession.h
index 458f5e08176311857709797ef6f7e2b0d8d3786b..d41724159b7d86fdb6aa09d01fdf4403868c6fee 100644
--- a/third_party/WebKit/Source/modules/mediasession/MediaSession.h
+++ b/third_party/WebKit/Source/modules/mediasession/MediaSession.h
@@ -6,6 +6,7 @@
#define MediaSession_h
#include "bindings/core/v8/ScriptWrappable.h"
+#include "core/events/EventTarget.h"
#include "modules/ModulesExport.h"
#include "platform/heap/Handle.h"
#include "public/platform/modules/mediasession/media_session.mojom-blink.h"
@@ -16,27 +17,47 @@ namespace blink {
class MediaMetadata;
class ScriptState;
-class MODULES_EXPORT MediaSession final
- : public GarbageCollectedFinalized<MediaSession>,
- public ScriptWrappable {
+class MODULES_EXPORT MediaSession final : public EventTargetWithInlineData {
DEFINE_WRAPPERTYPEINFO();
public:
- static MediaSession* create();
+ static MediaSession* create(ScriptState*);
- void setMetadata(ScriptState*, MediaMetadata*);
- MediaMetadata* metadata(ScriptState*) const;
+ void setMetadata(MediaMetadata*);
+ MediaMetadata* metadata() const;
+
+ // EventTarget implementation.
+ const WTF::AtomicString& interfaceName() const override;
+ ExecutionContext* getExecutionContext() const override;
+
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(play);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(pause);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(playpause);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(previoustrack);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(nexttrack);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(seekforward);
+ DEFINE_ATTRIBUTE_EVENT_LISTENER(seekbackward);
DECLARE_VIRTUAL_TRACE();
private:
friend class MediaSessionTest;
- MediaSession();
+ MediaSession(ScriptState*);
+
+ // EventTarget overrides
+ bool addEventListenerInternal(
+ const AtomicString& eventType,
+ EventListener*,
+ const AddEventListenerOptionsResolved&) override;
+ bool removeEventListenerInternal(const AtomicString& eventType,
+ const EventListener*,
+ const EventListenerOptions&) override;
// Returns null when the ExecutionContext is not document.
mojom::blink::MediaSessionService* getService(ScriptState*);
+ RefPtr<ScriptState> m_scriptState;
Member<MediaMetadata> m_metadata;
mojom::blink::MediaSessionServicePtr m_service;
};
« no previous file with comments | « third_party/WebKit/Source/modules/mediasession/DEPS ('k') | third_party/WebKit/Source/modules/mediasession/MediaSession.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698