Запрос курсора MediaStore с использованием определенной папки - PullRequest
10 голосов
/ 01 ноября 2011

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

Это работает для моего списка песен, так как этот курсор основан на MediaStore.Audio.Media.DATA, и я могу проверить это для папки в курсоре:

   final String folder = "'" + (new MyPrefs(this.PREF_PATH)).getString("music_folder",null) +  "%'";

    audioCursor = getContentResolver().query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, mCursorCols, 
            MediaStore.Audio.Media.DATA + " LIKE " + folder, null,MediaColumns.TITLE + " COLLATE LOCALIZED ASC");
    startManagingCursor(audioCursor);

Однако в моем Listview для художников результат DATA недоступен для проверки:

audioCursor = getContentResolver().query(MediaStore.Audio.Artists.EXTERNAL_CONTENT_URI, cols, 
            null, null,AudioColumns.ARTIST + " COLLATE LOCALIZED ASC");
        startManagingCursor(audioCursor);    

Может ли кто-нибудь поделиться со мной хорошим методом для запроса MediaStore.Audio.Artists.EXTERNAL_CONTENT_URI и возврата только моей конкретной папки? Мне нужно использовать URI исполнителя, потому что я использую столбец NUMBER_OF_TRACKS, который недоступен в обычном URI мультимедиа.

1 Ответ

4 голосов
/ 30 ноября 2011

Вы можете втиснуть в свой выбор все, что захотите, например, этот суб-выбор - который должен решить вашу проблему:

// The folder needs to end with the % wildcard or stuff doesn't work properly.
String folder = "/mnt/sdcard/Music/Some Folder/";
folder = folder + "%";
String where = Artists._ID + " IN (SELECT " + Media.ARTIST_ID + " FROM audio WHERE " +
    Media.DATA + " LIKE ?)";
String[] whereArgs = new String[]{folder};
audioCursor = getContentResolver().query(MediaStore.Audio.Artist.EXTERNAL_CONTENT_URI,
    cols, where, whereArgs, AudioColumns.ARTIST + " COLLATE LOCALIZED ASC");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...