Какова Строка 'volumeName' аргумент MediaStore. Аудио. Плей-листы. Members.getContentUri, относящийся к?

Я желаю запросить членов данного плей-листа. Я имею корректный идентификатор плей-листа и хочу использовать managedQuery () для рассмотрения рассматриваемых участников плей-листа.

То, что я имею, является этим:

private String [] columns = { 
     MediaStore.Audio.Playlists.Members.PLAYLIST_ID,
     MediaStore.Audio.Playlists.Members.TITLE,
     };
Uri membersUri = MediaStore.Audio.Playlists.Members.getContentUri(volume, playlistId);
Cursor tCursor = managedQuery(membersUri, columns, null, null, null);

Я не знаю, каков аргумент объема должен быть. Я попробовал это: MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI.toString() для аргумента "объема".

Это дает мне назад допустимое содержание URI, который похож:

content://media/external/audio/playlists/2/members

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

11
задан Brett 13 April 2010 в 06:10
поделиться

1 ответ

Строка "external" работает как том в MediaStore.Audio.Playlists.Members.getContentUri (volume, playlistId)

Это действие печатает песни на Android, списки воспроизведения и их содержимое.

import android.app.Activity;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.provider.MediaStore;
import android.util.Log;

public class PlaylistActivity extends Activity {
    private final String [] STAR= {"*"};
    private final String TAG= "list";

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //setContentView(R.layout.main);

        Log.i(TAG, "All the titles");
        Uri allaudio_uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
        Cursor ca= managedQuery(allaudio_uri, STAR, null,null,null);
        for(ca.moveToFirst(); !ca.isAfterLast(); ca.moveToNext()){
            if(ca.isFirst()){   // print all the fields of the first song
                for(int k= 0; k<ca.getColumnCount(); k++)
                    Log.i(TAG, "  "+ca.getColumnName(k)+"="+ca.getString(k));
            }else{              // but just the titles of the res
                Log.i(TAG, ca.getString(ca.getColumnIndex("title")));
            }
        }
        Log.i(TAG, "--------------------------");
        Log.i(TAG, "All the playlists");
        Uri playlist_uri= MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI;    
        Cursor cursor= managedQuery(playlist_uri, STAR, null,null,null);
        cursor.moveToFirst();
        for(int r= 0; r<cursor.getCount(); r++, cursor.moveToNext()){
            Log.i(TAG, "-----");
            Log.i(TAG, "Playlist " + cursor.getString(cursor.getColumnIndex("name")));
            for(int k= 0; k<cursor.getColumnCount(); k++)           
                Log.i(TAG, cursor.getColumnName(k)+"="+cursor.getString(k));

            // the members of this playlist
            int id= cursor.getInt(0);
            Uri membersUri = MediaStore.Audio.Playlists.Members.getContentUri("external", id);
            Cursor membersCursor = managedQuery(membersUri, STAR, null, null, null);
            membersCursor.moveToFirst();
            for(int s= 0; s<membersCursor.getCount(); s++, membersCursor.moveToNext())
                Log.i(TAG, "  "+membersCursor.getString(membersCursor.getColumnIndex("title")));
            membersCursor.close();
        }
        cursor.close();
    }
}
9
ответ дан 3 December 2019 в 10:25
поделиться
Другие вопросы по тегам:

Похожие вопросы: