我正在为 Android 2.1 编写一个简单的音乐应用程序并偶然发现了这样一个问题:
在我的活动中,我有一个 ListView,其中包含专辑封面、专辑标题、艺术家和每行中的歌曲数量。我在 ContentProvider 中查询所有要放入 ListView 的值。但是 SDCARD 上的一些专辑没有专辑封面,我认为查询返回 NULL。结果在我的 ListView 中,我的专辑只有少数有封面。
我想做的是在查询 ContentProvider 时或在其他地方放置一些参数,如果查询返回 null 封面,则将我的默认图标作为专辑封面。我的意思是,如果 ContentProvider 没有返回任何内容作为封面,我想将我的默认图标放在这个地方。
也许我应该使用其他查询,而不是 ManagedCursor?
我看到了使用 IFNULL 子句(SELECT IFNULL(title, "------") AS title FROM books;)的类似数据库问题的解决方案。我认为它可以在某种程度上有所帮助,但是没有地方可以在 ContentProvider 查询中放置这样的子句。
有谁知道该怎么做?我在下面放了mu代码:
private void getAllAlbumsFromSDCARD()
{
String[] cols = { MediaStore.Audio.Albums.ALBUM, MediaStore.Audio.Albums.ALBUM_ART, MediaStore.Audio.Media.ARTIST,
MediaStore.Audio.Media._ID, MediaStore.Audio.Albums.NUMBER_OF_SONGS};
Uri allAlbumsUri = MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI;
albumsCursor = this.managedQuery(allAlbumsUri, cols, null, null, MediaStore.Audio.Media.ALBUM);
// SELECT IFNULL(title, "------") AS title FROM books;
Log.d(TAG, "" +albumsCursor.getCount());
if(albumsCursor!=null)
{
Log.d(TAG, "Managing cursor");
startManagingCursor(albumsCursor);
//
String[] from = new String[] { MediaStore.Audio.Albums.ALBUM_ART, MediaStore.Audio.Albums.ALBUM, MediaStore.Audio.Media.ARTIST,
MediaStore.Audio.Albums.NUMBER_OF_SONGS };
int[] to = new int[] { R.id.cover, R.id.album, R.id.artist, R.id.count };
ListAdapter albums = new SimpleCursorAdapter(this, R.layout.album_row, albumsCursor, from, to);
this.setListAdapter(albums);
}
}