1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
content / browser / media / session / audio_focus_delegate_android.h [blame]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_BROWSER_MEDIA_SESSION_AUDIO_FOCUS_DELEGATE_ANDROID_H_
#define CONTENT_BROWSER_MEDIA_SESSION_AUDIO_FOCUS_DELEGATE_ANDROID_H_
#include <jni.h>
#include "base/android/scoped_java_ref.h"
#include "base/memory/raw_ptr.h"
#include "content/browser/media/session/audio_focus_delegate.h"
#include "content/public/browser/web_contents_observer.h"
namespace media_session {
namespace mojom {
enum class AudioFocusType;
} // namespace mojom
} // namespace media_session
namespace content {
// AudioFocusDelegateAndroid handles the audio focus at a system level on
// Android. It is also proxying the JNI calls.
class AudioFocusDelegateAndroid : public AudioFocusDelegate,
public WebContentsObserver {
public:
explicit AudioFocusDelegateAndroid(MediaSessionImpl* media_session);
AudioFocusDelegateAndroid(const AudioFocusDelegateAndroid&) = delete;
AudioFocusDelegateAndroid& operator=(const AudioFocusDelegateAndroid&) =
delete;
~AudioFocusDelegateAndroid() override;
void Initialize();
AudioFocusResult RequestAudioFocus(
media_session::mojom::AudioFocusType audio_focus_type) override;
void AbandonAudioFocus() override;
std::optional<media_session::mojom::AudioFocusType> GetCurrentFocusType()
const override;
const base::UnguessableToken& request_id() const override;
void ReleaseRequestId() override {}
// Called when the Android system requests the MediaSession to be suspended.
// Called by Java through JNI.
void OnSuspend(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj);
// Called when the Android system requests the MediaSession to be resumed.
// Called by Java through JNI.
void OnResume(JNIEnv* env, const base::android::JavaParamRef<jobject>& obj);
// Called when the Android system requests the MediaSession to start ducking.
// Called by Java through JNI.
void OnStartDucking(JNIEnv* env, jobject obj);
// Called when the Android system requests the MediaSession to stop ducking.
// Called by Java through JNI.
void OnStopDucking(JNIEnv* env, jobject obj);
// Record when the Android system requests the MediaSession to duck.
// Called by Java through JNI.
void RecordSessionDuck(JNIEnv* env,
const base::android::JavaParamRef<jobject>& obj);
// This is not used by this delegate.
void MediaSessionInfoChanged(
const media_session::mojom::MediaSessionInfoPtr&) override {}
protected:
// WebContentsObserver
void OnAudioStateChanged(bool is_audible) override;
private:
// Weak pointer because |this| is owned by |media_session_|.
raw_ptr<MediaSessionImpl> media_session_;
base::android::ScopedJavaGlobalRef<jobject> j_media_session_delegate_;
bool is_deferred_gain_pending_ = false;
};
} // namespace content
#endif // CONTENT_BROWSER_MEDIA_SESSION_AUDIO_FOCUS_DELEGATE_ANDROID_H_