package android.media;

import android.annotation.Nullable;
import android.graphics.Bitmap;
import android.media.browse.MediaBrowser;
import android.net.Uri;
import android.os.Bundle;
import android.os.Parcel;
import android.os.Parcelable;

A simple set of metadata for a media item suitable for display. This can be created using the Builder or retrieved from existing metadata using MediaMetadata.getDescription().
/** * A simple set of metadata for a media item suitable for display. This can be * created using the Builder or retrieved from existing metadata using * {@link MediaMetadata#getDescription()}. */
public class MediaDescription implements Parcelable {
A unique persistent id for the content or null.
/** * A unique persistent id for the content or null. */
private final String mMediaId;
A primary title suitable for display or null.
/** * A primary title suitable for display or null. */
private final CharSequence mTitle;
A subtitle suitable for display or null.
/** * A subtitle suitable for display or null. */
private final CharSequence mSubtitle;
A description suitable for display or null.
/** * A description suitable for display or null. */
private final CharSequence mDescription;
A bitmap icon suitable for display or null.
/** * A bitmap icon suitable for display or null. */
private final Bitmap mIcon;
A Uri for an icon suitable for display or null.
/** * A Uri for an icon suitable for display or null. */
private final Uri mIconUri;
Extras for opaque use by apps/system.
/** * Extras for opaque use by apps/system. */
private final Bundle mExtras;
A Uri to identify this content.
/** * A Uri to identify this content. */
private final Uri mMediaUri;
Used as a long extra field to indicate the bluetooth folder type of the media item as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5. This is valid only for MediaItem with MediaItem.FLAG_BROWSABLE. The value should be one of the following:
See Also:
/** * Used as a long extra field to indicate the bluetooth folder type of the media item as * specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5. This is valid only for * {@link MediaBrowser.MediaItem} with {@link MediaBrowser.MediaItem#FLAG_BROWSABLE}. The value * should be one of the following: * <ul> * <li>{@link #BT_FOLDER_TYPE_MIXED}</li> * <li>{@link #BT_FOLDER_TYPE_TITLES}</li> * <li>{@link #BT_FOLDER_TYPE_ALBUMS}</li> * <li>{@link #BT_FOLDER_TYPE_ARTISTS}</li> * <li>{@link #BT_FOLDER_TYPE_GENRES}</li> * <li>{@link #BT_FOLDER_TYPE_PLAYLISTS}</li> * <li>{@link #BT_FOLDER_TYPE_YEARS}</li> * </ul> * * @see #getExtras() */
public static final String EXTRA_BT_FOLDER_TYPE = "android.media.extra.BT_FOLDER_TYPE";
The type of folder that is unknown or contains media elements of mixed types as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that is unknown or contains media elements of mixed types as specified in * the section 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_MIXED = 0;
The type of folder that contains media elements only as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains media elements only as specified in the section 6.10.2.2 of * the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_TITLES = 1;
The type of folder that contains folders categorized by album as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains folders categorized by album as specified in the section * 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_ALBUMS = 2;
The type of folder that contains folders categorized by artist as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains folders categorized by artist as specified in the section * 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_ARTISTS = 3;
The type of folder that contains folders categorized by genre as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains folders categorized by genre as specified in the section * 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_GENRES = 4;
The type of folder that contains folders categorized by playlist as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains folders categorized by playlist as specified in the section * 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_PLAYLISTS = 5;
The type of folder that contains folders categorized by year as specified in the section 6.10.2.2 of the Bluetooth AVRCP 1.5.
/** * The type of folder that contains folders categorized by year as specified in the section * 6.10.2.2 of the Bluetooth AVRCP 1.5. */
public static final long BT_FOLDER_TYPE_YEARS = 6; private MediaDescription(String mediaId, CharSequence title, CharSequence subtitle, CharSequence description, Bitmap icon, Uri iconUri, Bundle extras, Uri mediaUri) { mMediaId = mediaId; mTitle = title; mSubtitle = subtitle; mDescription = description; mIcon = icon; mIconUri = iconUri; mExtras = extras; mMediaUri = mediaUri; } private MediaDescription(Parcel in) { mMediaId = in.readString(); mTitle = in.readCharSequence(); mSubtitle = in.readCharSequence(); mDescription = in.readCharSequence(); mIcon = in.readParcelable(null); mIconUri = in.readParcelable(null); mExtras = in.readBundle(); mMediaUri = in.readParcelable(null); }
Returns the media id or null. See MediaMetadata.METADATA_KEY_MEDIA_ID.
/** * Returns the media id or null. See * {@link MediaMetadata#METADATA_KEY_MEDIA_ID}. */
public @Nullable String getMediaId() { return mMediaId; }
Returns a title suitable for display or null.
Returns:A title or null.
/** * Returns a title suitable for display or null. * * @return A title or null. */
public @Nullable CharSequence getTitle() { return mTitle; }
Returns a subtitle suitable for display or null.
Returns:A subtitle or null.
/** * Returns a subtitle suitable for display or null. * * @return A subtitle or null. */
public @Nullable CharSequence getSubtitle() { return mSubtitle; }
Returns a description suitable for display or null.
Returns:A description or null.
/** * Returns a description suitable for display or null. * * @return A description or null. */
public @Nullable CharSequence getDescription() { return mDescription; }
Returns a bitmap icon suitable for display or null.
Returns:An icon or null.
/** * Returns a bitmap icon suitable for display or null. * * @return An icon or null. */
public @Nullable Bitmap getIconBitmap() { return mIcon; }
Returns a Uri for an icon suitable for display or null.
Returns:An icon uri or null.
/** * Returns a Uri for an icon suitable for display or null. * * @return An icon uri or null. */
public @Nullable Uri getIconUri() { return mIconUri; }
Returns any extras that were added to the description.
Returns:A bundle of extras or null.
/** * Returns any extras that were added to the description. * * @return A bundle of extras or null. */
public @Nullable Bundle getExtras() { return mExtras; }
Returns a Uri representing this content or null.
Returns:A media Uri or null.
/** * Returns a Uri representing this content or null. * * @return A media Uri or null. */
public @Nullable Uri getMediaUri() { return mMediaUri; } @Override public int describeContents() { return 0; } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeString(mMediaId); dest.writeCharSequence(mTitle); dest.writeCharSequence(mSubtitle); dest.writeCharSequence(mDescription); dest.writeParcelable(mIcon, flags); dest.writeParcelable(mIconUri, flags); dest.writeBundle(mExtras); dest.writeParcelable(mMediaUri, flags); } @Override public boolean equals(Object o) { if (o == null) { return false; } if (!(o instanceof MediaDescription)){ return false; } final MediaDescription d = (MediaDescription) o; if (!String.valueOf(mTitle).equals(String.valueOf(d.mTitle))) { return false; } if (!String.valueOf(mSubtitle).equals(String.valueOf(d.mSubtitle))) { return false; } if (!String.valueOf(mDescription).equals(String.valueOf(d.mDescription))) { return false; } return true; } @Override public String toString() { return mTitle + ", " + mSubtitle + ", " + mDescription; } public static final Parcelable.Creator<MediaDescription> CREATOR = new Parcelable.Creator<MediaDescription>() { @Override public MediaDescription createFromParcel(Parcel in) { return new MediaDescription(in); } @Override public MediaDescription[] newArray(int size) { return new MediaDescription[size]; } };
Builder for MediaDescription objects.
/** * Builder for {@link MediaDescription} objects. */
public static class Builder { private String mMediaId; private CharSequence mTitle; private CharSequence mSubtitle; private CharSequence mDescription; private Bitmap mIcon; private Uri mIconUri; private Bundle mExtras; private Uri mMediaUri;
Creates an initially empty builder.
/** * Creates an initially empty builder. */
public Builder() { }
Sets the media id.
Params:
  • mediaId – The unique id for the item or null.
Returns:this
/** * Sets the media id. * * @param mediaId The unique id for the item or null. * @return this */
public Builder setMediaId(@Nullable String mediaId) { mMediaId = mediaId; return this; }
Sets the title.
Params:
  • title – A title suitable for display to the user or null.
Returns:this
/** * Sets the title. * * @param title A title suitable for display to the user or null. * @return this */
public Builder setTitle(@Nullable CharSequence title) { mTitle = title; return this; }
Sets the subtitle.
Params:
  • subtitle – A subtitle suitable for display to the user or null.
Returns:this
/** * Sets the subtitle. * * @param subtitle A subtitle suitable for display to the user or null. * @return this */
public Builder setSubtitle(@Nullable CharSequence subtitle) { mSubtitle = subtitle; return this; }
Sets the description.
Params:
  • description – A description suitable for display to the user or null.
Returns:this
/** * Sets the description. * * @param description A description suitable for display to the user or * null. * @return this */
public Builder setDescription(@Nullable CharSequence description) { mDescription = description; return this; }
Sets the icon.
Params:
  • icon – A Bitmap icon suitable for display to the user or null.
Returns:this
/** * Sets the icon. * * @param icon A {@link Bitmap} icon suitable for display to the user or * null. * @return this */
public Builder setIconBitmap(@Nullable Bitmap icon) { mIcon = icon; return this; }
Sets the icon uri.
Params:
  • iconUri – A Uri for an icon suitable for display to the user or null.
Returns:this
/** * Sets the icon uri. * * @param iconUri A {@link Uri} for an icon suitable for display to the * user or null. * @return this */
public Builder setIconUri(@Nullable Uri iconUri) { mIconUri = iconUri; return this; }
Sets a bundle of extras.
Params:
  • extras – The extras to include with this description or null.
Returns:this
/** * Sets a bundle of extras. * * @param extras The extras to include with this description or null. * @return this */
public Builder setExtras(@Nullable Bundle extras) { mExtras = extras; return this; }
Sets the media uri.
Params:
  • mediaUri – The content's Uri for the item or null.
Returns:this
/** * Sets the media uri. * * @param mediaUri The content's {@link Uri} for the item or null. * @return this */
public Builder setMediaUri(@Nullable Uri mediaUri) { mMediaUri = mediaUri; return this; } public MediaDescription build() { return new MediaDescription(mMediaId, mTitle, mSubtitle, mDescription, mIcon, mIconUri, mExtras, mMediaUri); } } }