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

Side by Side Diff: content/renderer/media/renderer_webmediaplayer_delegate.h

Issue 1570043002: Implement MediaSession on top of the WebMediaPlayerDelegate. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@media_session
Patch Set: Reorder. 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_ 5 #ifndef CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_
6 #define CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_ 6 #define CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_
7 7
8 #include "base/id_map.h"
8 #include "base/macros.h" 9 #include "base/macros.h"
9 #include "base/memory/weak_ptr.h" 10 #include "base/memory/weak_ptr.h"
10 #include "base/observer_list.h"
11 #include "content/public/renderer/render_frame_observer.h" 11 #include "content/public/renderer/render_frame_observer.h"
12 #include "media/blink/webmediaplayer_delegate.h" 12 #include "media/blink/webmediaplayer_delegate.h"
13 13
14 namespace blink { 14 namespace blink {
15 class WebMediaPlayer; 15 class WebMediaPlayer;
16 } 16 }
17 17
18 namespace media { 18 namespace media {
19 19
20 // An interface to allow a WebMediaPlayerImpl to communicate changes of state 20 // An interface to allow a WebMediaPlayerImpl to communicate changes of state
21 // to objects that need to know. 21 // to objects that need to know.
22 class RendererWebMediaPlayerDelegate 22 class RendererWebMediaPlayerDelegate
23 : public content::RenderFrameObserver, 23 : public content::RenderFrameObserver,
24 public WebMediaPlayerDelegate, 24 public WebMediaPlayerDelegate,
25 public base::SupportsWeakPtr<RendererWebMediaPlayerDelegate> { 25 public base::SupportsWeakPtr<RendererWebMediaPlayerDelegate> {
26 public: 26 public:
27 explicit RendererWebMediaPlayerDelegate(content::RenderFrame* render_frame); 27 explicit RendererWebMediaPlayerDelegate(content::RenderFrame* render_frame);
28 ~RendererWebMediaPlayerDelegate() override; 28 ~RendererWebMediaPlayerDelegate() override;
29 29
30 // Returns true if this RenderFrame has ever seen media playback before. 30 // Returns true if this RenderFrame has ever seen media playback before.
31 bool has_played_media() const { return has_played_media_; } 31 bool has_played_media() const { return has_played_media_; }
32 32
33 // WebMediaPlayerDelegate implementation. 33 // WebMediaPlayerDelegate implementation.
34 void DidPlay(blink::WebMediaPlayer* player) override; 34 int AddObserver(Observer* observer) override;
35 void DidPause(blink::WebMediaPlayer* player) override; 35 void RemoveObserver(int delegate_id) override;
36 void PlayerGone(blink::WebMediaPlayer* player) override; 36 void DidPlay(int delegate_id,
37 void AddObserver(Observer* observer) override; 37 bool has_video,
38 void RemoveObserver(Observer* observer) override; 38 bool has_audio,
39 bool is_remote,
40 base::TimeDelta duration) override;
41 void DidPause(int delegate_id, bool reached_end_of_stream) override;
42 void PlayerGone(int delegate_id) override;
39 bool IsHidden() override; 43 bool IsHidden() override;
40 44
41 // content::RenderFrameObserver overrides. 45 // content::RenderFrameObserver overrides.
42 void WasHidden() override; 46 void WasHidden() override;
43 void WasShown() override; 47 void WasShown() override;
48 bool OnMessageReceived(const IPC::Message& msg) override;
44 49
45 private: 50 private:
51 void OnMediaDelegatePause(int delegate_id);
52 void OnMediaDelegatePlay(int delegate_id);
53 void OnMediaDelegateVolumeMultiplierUpdate(int delegate_id,
54 double multiplier);
55
46 bool has_played_media_ = false; 56 bool has_played_media_ = false;
47 base::ObserverList<Observer> observer_list_; 57 IDMap<Observer> id_map_;
48 58
49 DISALLOW_COPY_AND_ASSIGN(RendererWebMediaPlayerDelegate); 59 DISALLOW_COPY_AND_ASSIGN(RendererWebMediaPlayerDelegate);
50 }; 60 };
51 61
52 } // namespace media 62 } // namespace media
53 63
54 #endif // CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_ 64 #endif // CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_
OLDNEW
« no previous file with comments | « content/renderer/media/android/webmediaplayer_android.cc ('k') | content/renderer/media/renderer_webmediaplayer_delegate.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698