Запрос выбора MediaStore возвращает только одну строку - PullRequest
0 голосов
/ 03 мая 2020

Я пытаюсь разработать проигрыватель musi c, я создал загрузчик и адаптер для извлечения моих данных из mediastore, но когда я вызываю запрос из моего приложения, он возвращает только одну строку, я не знаю, не так с моим кодом, вы поможете мне решить эту проблему?

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

public static List<Song> getAllArtistSongs(Context context, long artist_id){
    List<Song> ArtistSongList = new ArrayList<>();
    Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
    String[] projection = new String[]{
            "_id",
            "title",
            "album_id",
            "album",
            "artist",
            "duration",
            "track"
    };
    String sortorder = MediaStore.Audio.Media.DEFAULT_SORT_ORDER;
    String selection = "is_music=1 and artist_id="+artist_id;

    Cursor cursor = context.getContentResolver().query(uri, projection, selection, null, sortorder);
    assert cursor != null;
    if (cursor.moveToFirst()) {
            do {
                int trackNumber = cursor.getInt(6);
                while (trackNumber >= 1000) {
                    trackNumber -= 1000;
                }
                Long id = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media._ID));
                String title = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.TITLE));
                Long albumid = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.ALBUM_ID));
                String albumname = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.ALBUM));
                String artistname = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.ARTIST));
                int duration = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.DURATION));
                ArtistSongList.add(new Song(id, title, albumid, albumname, artist_id, artistname, duration, trackNumber));
            } while (cursor.moveToNext());
        cursor.close();
    }
    return ArtistSongList;
}

А это адаптер, который я используйте, чтобы привязать к представлению переработчика

1 Ответ

0 голосов
/ 04 мая 2020

Мой пример для извлечения всех треков:

private final String track_id = MediaStore.Audio.Media._ID;
private final String track_no = MediaStore.Audio.Media.TRACK;
private final String track_name = MediaStore.Audio.Media.TITLE;
private final String artist = MediaStore.Audio.Media.ARTIST;
private final String artist_id = MediaStore.Audio.Media.ARTIST_ID;
private final String duration = MediaStore.Audio.Media.DURATION;
private final String album = MediaStore.Audio.Media.ALBUM;
private final String composer = MediaStore.Audio.Media.COMPOSER;
private final String year = MediaStore.Audio.Media.YEAR;
private final String path = MediaStore.Audio.Media.DATA;
private final String date_added = MediaStore.Audio.Media.DATE_ADDED;

    public Cursor getAllTracks(Context context) {
    // gets all tracks
    if (context != null) {
        ContentResolver cr = context.getContentResolver();
        final String[] columns = {track_id, track_no, artist, track_name,
                album, duration, path, year, composer};
        return cr.query(uri, columns, null, null, null);
    } else {
        return null;
    }
}

, сначала у вас есть

String selection = "is_music=1"

, вам не нужно is_music = 1. Для нескольких треков вам, конечно, нужно более 1 трека одного и того же исполнителя. Адаптер не имеет значения, запрос делает выбор

Чтобы вернуть альбомы для исполнителя

    public Cursor getArtistsAlbumcursor(Context context, String artistId) {
    ContentResolver cr = context.getContentResolver();
    final String _id = MediaStore.Audio.Media._ID;
    final String album_id = MediaStore.Audio.Media.ALBUM_ID;
    final String artistid = MediaStore.Audio.Media.ARTIST_ID;
    final String[] columns = {_id, album_id, artistid};
    if (artistId != null) {
        String where = artistid + " =?";
        String[] aId = {artistId};
        return cr.query(uri, columns, where, aId, null);
    } else {
        return null;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...