diff options
author | RoboErik <epastern@google.com> | 2014-05-20 18:03:31 -0700 |
---|---|---|
committer | RoboErik <epastern@google.com> | 2014-05-21 17:43:18 -0700 |
commit | 33983a901176adcc16c820444b667a37e6472243 (patch) | |
tree | 85da46326a455cd7cc9617e21ab638241a827398 | |
parent | c106c12e566d48e81a0ad0bf7ee614c50c6aef39 (diff) | |
download | frameworks_base-33983a901176adcc16c820444b667a37e6472243.zip frameworks_base-33983a901176adcc16c820444b667a37e6472243.tar.gz frameworks_base-33983a901176adcc16c820444b667a37e6472243.tar.bz2 |
Add stream/volume apis to sessions
This adds RemoteVolumeProviders which handle volume change
events and a way to switch a session between local stream
playback and remote playback handling.
This also adds a way for an app to specify the PendingIntent
to launch when we want to show their ongoing playback UI.
Change-Id: I3a72bf2ec7ca55f61f50859ddc2988eebd491e9d
-rw-r--r-- | api/current.txt | 15 | ||||
-rw-r--r-- | media/java/android/media/session/MediaSession.java | 48 | ||||
-rw-r--r-- | media/java/android/media/session/RemoteVolumeProvider.java | 84 |
3 files changed, 146 insertions, 1 deletions
diff --git a/api/current.txt b/api/current.txt index b2fe641..646c495 100644 --- a/api/current.txt +++ b/api/current.txt @@ -15746,6 +15746,9 @@ package android.media.session { method public void sendEvent(java.lang.String, android.os.Bundle); method public void setActive(boolean); method public void setFlags(int); + method public void setLaunchPendingIntent(android.app.PendingIntent); + method public void useLocalPlayback(android.media.AudioAttributes); + method public void useRemotePlayback(android.media.session.RemoteVolumeProvider); field public static final int FLAG_HANDLES_MEDIA_BUTTONS = 1; // 0x1 field public static final int FLAG_HANDLES_TRANSPORT_CONTROLS = 2; // 0x2 } @@ -15814,6 +15817,18 @@ package android.media.session { field public static final int PLAYSTATE_STOPPED = 1; // 0x1 } + public abstract class RemoteVolumeProvider { + ctor public RemoteVolumeProvider(int, int); + method public abstract int getCurrentVolume(); + method public final int getFlags(); + method public final int getMaxVolume(); + method public final void notifyVolumeChanged(); + method public void onAdjustVolume(int); + method public void onSetVolume(int); + field public static final int FLAG_VOLUME_ABSOLUTE = 2; // 0x2 + field public static final int FLAG_VOLUME_RELATIVE = 1; // 0x1 + } + public final class TransportController { method public void addStateListener(android.media.session.TransportController.TransportStateListener); method public void addStateListener(android.media.session.TransportController.TransportStateListener, android.os.Handler); diff --git a/media/java/android/media/session/MediaSession.java b/media/java/android/media/session/MediaSession.java index 6a62dc2..24bbc49 100644 --- a/media/java/android/media/session/MediaSession.java +++ b/media/java/android/media/session/MediaSession.java @@ -16,7 +16,10 @@ package android.media.session; +import android.app.PendingIntent; import android.content.Intent; +import android.media.AudioAttributes; +import android.media.AudioManager; import android.media.Rating; import android.media.session.ISessionController; import android.media.session.ISession; @@ -89,6 +92,7 @@ public final class MediaSession { /** * Indicates the session was disconnected because the user that the session * belonged to is stopping. + * * @hide */ public static final int DISCONNECT_REASON_USER_STOPPING = 1; @@ -218,6 +222,16 @@ public final class MediaSession { } /** + * Set an intent for launching UI for this Session. This can be used as a + * quick link to an ongoing media screen. + * + * @param pi The intent to launch to show UI for this Session. + */ + public void setLaunchPendingIntent(PendingIntent pi) { + // TODO + } + + /** * Set any flags for the session. * * @param flags The flags to set for this session. @@ -231,6 +245,38 @@ public final class MediaSession { } /** + * Set the attributes for this session's local playback. This will affect + * the system's default volume handling for this session. If + * {@link #useRemotePlayback} was previously called it will stop receiving + * volume commands and the system will begin handling volume changes. + * <p> + * By default sessions use {@link AudioAttributes#USAGE_MEDIA}. + * + * @param attributes The {@link AudioAttributes} for this session's + * playback. + */ + public void useLocalPlayback(AudioAttributes attributes) { + // TODO + } + + /** + * Configure this session to use remote volume handling. This must be called + * to receive volume button events, otherwise the system will adjust the + * current stream volume for this session. If {@link #useLocalPlayback} was + * previously called that stream will stop receiving volume changes for this + * session. + * + * @param volumeProvider The provider that will handle volume changes. May + * not be null. + */ + public void useRemotePlayback(RemoteVolumeProvider volumeProvider) { + if (volumeProvider == null) { + throw new IllegalArgumentException("volumeProvider may not be null!"); + } + // TODO + } + + /** * Set if this session is currently active and ready to receive commands. If * set to false your session's controller may not be discoverable. You must * set the session to active before it can start receiving media button @@ -461,7 +507,7 @@ public final class MediaSession { /** * Receives commands or updates from controllers and routes. An app can * specify what commands and buttons it supports by setting them on the - * MediaSession (TODO). + * MediaSession. */ public abstract static class Callback { diff --git a/media/java/android/media/session/RemoteVolumeProvider.java b/media/java/android/media/session/RemoteVolumeProvider.java new file mode 100644 index 0000000..9526cc8 --- /dev/null +++ b/media/java/android/media/session/RemoteVolumeProvider.java @@ -0,0 +1,84 @@ +package android.media.session; + +/** + * Handles requests to adjust or set the volume on a session. This is also used + * to push volume updates back to the session after a request has been handled. + * You can set a volume provider on a session by calling + * {@link MediaSession#useRemotePlayback}. + */ +public abstract class RemoteVolumeProvider { + + /** + * Handles relative volume changes via {@link #onAdjustVolume(int)}. + */ + public static final int FLAG_VOLUME_RELATIVE = 1 << 0; + + /** + * Handles setting the volume via {@link #onSetVolume(int)}. + */ + public static final int FLAG_VOLUME_ABSOLUTE = 1 << 1; + + private final int mFlags; + private final int mMaxVolume; + + /** + * Create a new volume provider for handling volume events. You must specify + * the type of events and the maximum volume that can be used. + * + * @param flags The flags to use with this provider. + * @param maxVolume The maximum allowed volume. + */ + public RemoteVolumeProvider(int flags, int maxVolume) { + mFlags = flags; + mMaxVolume = maxVolume; + } + + /** + * Get the current volume of the remote playback. + * + * @return The current volume. + */ + public abstract int getCurrentVolume(); + + /** + * Get the flags that were set for this volume provider. + * + * @return The flags for this volume provider + */ + public final int getFlags() { + return mFlags; + } + + /** + * Get the maximum volume this provider allows. + * + * @return The max allowed volume. + */ + public final int getMaxVolume() { + return mMaxVolume; + } + + /** + * Notify the system that the remove playback's volume has been changed. + */ + public final void notifyVolumeChanged() { + // TODO + } + + /** + * Override to handle requests to set the volume of the current output. + * + * @param volume The volume to set the output to. + */ + public void onSetVolume(int volume) { + } + + /** + * Override to handle requests to adjust the volume of the current + * output. + * + * @param delta The amount to change the volume + */ + public void onAdjustVolume(int delta) { + } +}
\ No newline at end of file |