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

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: Rebase yet again. Created 4 years, 11 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/macros.h" 8 #include "base/macros.h"
9 #include "base/memory/weak_ptr.h" 9 #include "base/memory/weak_ptr.h"
10 #include "base/observer_list.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 the player id for a given observer.
31 // TODO(dalecurtis): Remove once RendererWebMediaPlayerManager is removed.
32 static int64_t GetPlayerId(Observer* observer);
33
30 // Returns true if this RenderFrame has ever seen media playback before. 34 // Returns true if this RenderFrame has ever seen media playback before.
31 bool has_played_media() const { return has_played_media_; } 35 bool has_played_media() const { return has_played_media_; }
32 36
33 // WebMediaPlayerDelegate implementation. 37 // WebMediaPlayerDelegate implementation.
34 void DidPlay(blink::WebMediaPlayer* player) override;
35 void DidPause(blink::WebMediaPlayer* player) override;
36 void PlayerGone(blink::WebMediaPlayer* player) override;
37 void AddObserver(Observer* observer) override; 38 void AddObserver(Observer* observer) override;
38 void RemoveObserver(Observer* observer) override; 39 void RemoveObserver(Observer* observer) override;
40 void DidPlay(Observer* observer,
41 bool has_video,
42 bool has_audio,
43 bool is_remote,
44 base::TimeDelta duration) override;
45 void DidPause(Observer* observer, bool reached_end_of_stream) override;
46 void PlayerGone(Observer* observer) override;
39 bool IsHidden() override; 47 bool IsHidden() override;
40 48
41 // content::RenderFrameObserver overrides. 49 // content::RenderFrameObserver overrides.
42 void WasHidden() override; 50 void WasHidden() override;
43 void WasShown() override; 51 void WasShown() override;
52 bool OnMessageReceived(const IPC::Message& msg) override;
44 53
45 private: 54 private:
55 bool GetObserver(int64_t player_cookie, Observer** observer);
56 void OnMediaDelegatePause(int64_t player_cookie);
57 void OnMediaDelegatePlay(int64_t player_cookie);
58 void OnMediaDelegateVolumeMultiplierUpdate(int64_t player_cookie,
59 double multiplier);
60
46 bool has_played_media_ = false; 61 bool has_played_media_ = false;
47 base::ObserverList<Observer> observer_list_; 62 base::ObserverList<Observer> observer_list_;
48 63
49 DISALLOW_COPY_AND_ASSIGN(RendererWebMediaPlayerDelegate); 64 DISALLOW_COPY_AND_ASSIGN(RendererWebMediaPlayerDelegate);
50 }; 65 };
51 66
52 } // namespace media 67 } // namespace media
53 68
54 #endif // CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_ 69 #endif // CONTENT_RENDERER_MEDIA_RENDERER_WEBMEDIAPLAYER_DELEGATE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698