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

Side by Side Diff: content/browser/media/session/media_session_delegate_android.h

Issue 2439483003: Link MediaSessionTabHelper with native MediaSession [CL is going to be split] (Closed)
Patch Set: Super rough, please give some initial feedbacks 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 unified diff | Download patch
OLDNEW
(Empty)
1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #ifndef CONTENT_BROWSER_MEDIA_SESSION_MEDIA_SESSION_DELEGATE_ANDROID_H_
6 #define CONTENT_BROWSER_MEDIA_SESSION_MEDIA_SESSION_DELEGATE_ANDROID_H_
7
8 #include <jni.h>
9
10 #include "base/android/scoped_java_ref.h"
11 #include "content/browser/media/session/media_session_observer.h"
12
13 namespace content {
14
15 class MediaSessionDelegateAndroid : public MediaSessionObserver {
16 public:
17
18 static bool Register(JNIEnv* env);
19
20 static void CreateAndRegister(
21 JNIEnv* env,
22 MediaSession* media_session,
23 const base::android::JavaParamRef<jobject>& j_delegate);
24
25 ~MediaSessionDelegateAndroid() override;
26
27 // MediaSessionObserver implementations
28 void MediaSessionDisconnected() override;
29 void MediaSessionStateChanged(bool is_controllable, bool is_suspended) overrid e;
30 void MediaSessionMetadataChanged(const base::Optional<MediaMetadata>& metadata ) override;
31
32 void ResumeMediaSession(JNIEnv* env, const base::android::JavaParamRef<jobject >& obj);
33 void SuspendMediaSession(JNIEnv* env, const base::android::JavaParamRef<jobjec t>& obj);
34 void StopMediaSession(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj);
35 void UnlinkMediaSession(JNIEnv* env, const base::android::JavaParamRef<jobject >& obj);
36
37 private:
38 MediaSessionDelegateAndroid(
39 MediaSession* media_session,
40 const base::android::JavaParamRef<jobject>& j_delegate);
41
42 base::android::ScopedJavaGlobalRef<jobject> j_delegate_;
boliu 2016/10/19 20:39:40 this is content, so need to be safe for android we
Zhiqiang Zhang (Slow) 2016/10/20 16:22:32 You are right. For our case, we don't need strong
whywhat 2016/10/21 18:31:02 Would a guarantee like "when WebContents is destro
boliu 2016/10/21 19:56:02 No, because WebContents is destroyed by gc, so if
43
44 DISALLOW_COPY_AND_ASSIGN(MediaSessionDelegateAndroid);
45 };
46
47 } // namespace content
48
49 #endif // CONTENT_BROWSER_MEDIA_SESSION_MEDIA_SESSION_DELEGATE_ANDROID_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698