Mediastore альбомы и медиа-колонки

Слишком восстановить идентификатор альбома, который я использую:

String SONG_ALBUMID  = MediaStore.Audio.Albums.ALBUM_ID;

Но в чем разница между MediaStore.Audio.Albums.ALBUM_ID и MediaStore.Audio.Media.ALBUM_ID

Спасибо,

2 ответа

MediaStore.Audio.Albums.ALBUM_ID - это идентификатор альбома из таблицы альбомов, а MediaStore.Audio.Media.ALBUM_ID - это "внешний ключ" album_id в таблице файлов. В общем случае реляционная база данных такова, что при доступе к таблице файлов все, что нам нужно, это abum_id для доступа к таблице альбомов и получения всей необходимой информации об альбомах, такой как album_title. Файлы таблиц в базе данных Android содержат много деталей, например

_id INTEGER
_data   TEXT
_size   INTEGER
format  INTEGER
parent  INTEGER
date_added  INTEGER
date_modified   INTEGER
mime_type   TEXT
title   TEXT
description TEXT
_display_name   TEXT
picasa_id   TEXT
orientation INTEGER
latitude    DOUBLE
longitude   DOUBLE
datetaken   INTEGER
mini_thumb_magic    INTEGER
bucket_id   TEXT
bucket_display_name TEXT
isprivate   INTEGER
title_key   TEXT
artist_id   INTEGER
album_id    INTEGER
composer    TEXT
track   INTEGER
year    INTEGER
is_ringtone INTEGER
is_music    INTEGER
is_alarm    INTEGER
is_notification INTEGER
is_podcast  INTEGER
album_artist    TEXT
duration    INTEGER
bookmark    INTEGER
artist  TEXT
album   TEXT
resolution  TEXT
tags    TEXT
category    TEXT
language    TEXT
mini_thumb_data TEXT
name    TEXT
media_type  INTEGER
old_id  INTEGER
storage_id  INTEGER
is_drm  INTEGER
width   INTEGER
height  INTEGER

Вот 2 подхода: (включите запрошенные столбцы в ваш resolver.query)

     public String getalbum_id(Cursor pcursor) {
    int album_col = pcursor
            .getColumnIndexOrThrow(MediaStore.Audio.Media.ALBUM_ID);
    String album_id = pcursor.getString(album_col);

    if (album_id.length() > 0) {
        return album_id;
    } else {
        return "";
    }
}

public String getAlbumIdfromPath(Context context, String datapath) {
    ContentResolver cr = context.getContentResolver();
    final String _id = MediaStore.Audio.Media._ID;
    final String path = MediaStore.Audio.Media.DATA;
    final String album_id = MediaStore.Audio.Media.ALBUM_ID;
    final String[] columns = {_id, album_id};
    final String[] trackpath = {"%" + datapath + "%"};
    String where = path + " LIKE ?";
    String stralbum_id = null;
    Cursor crs = cr.query(uri, columns, where, trackpath, null);
    if (crs != null && crs.moveToFirst()) {
        stralbum_id = crs.getString(crs.getColumnIndexOrThrow(album_id));
        crs.close();
    }
    return stralbum_id;
}

Теперь, чтобы показать, я разместил ранее, но я использую библиотеку Gilde. Это делает всю тяжелую работу.

            //  loading album cover using Glide library
        String artist_id = (c.getString(c
                .getColumnIndex(MediaStore.Audio.Artists._ID)));
        Cursor albs = albums.getArtistsAlbumcursor(mContext, artist_id);
        String stralbumId=null;
        if(albs!=null && albs.moveToFirst()){
           stralbumId= albs.getString(albs.getColumnIndexOrThrow(MediaStore.Audio.Media.ALBUM_ID));
        }
        Uri ImageUrl = plist.getAlbumUri(mContext, stralbumId);
        if (ImageUrl != null) {
            Glide.with(mContext)
                    .asBitmap()
                    .load(ImageUrl)
                    .into(image);
        }
    }

где getAlbumuri это:

     public Uri getAlbumUri(Context mContext,String album_id){
    if(mContext!=null) {
        Uri sArtworkUri = Uri.parse("content://media/external/audio/albumart");
        Uri imageUri = Uri.withAppendedPath(sArtworkUri, String.valueOf(album_id));
        return imageUri;
    }
    return null;
}

Включите следующее в ваш модуль build.gradle

    implementation 'com.github.bumptech.glide:glide:4.5.0'
annotationProcessor 'com.github.bumptech.glide:compiler:4.7.1'

   private final Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
Другие вопросы по тегам