OPhone系统提供了 MediaScanner,MediaProvider,MediaStore等接口,并且提供了一套数据库表格,通过Content Provider的方式提供给用户。当手机开机或者有SD卡插拔等事件发生时,系统将会自动扫描SD卡和手机内存上的媒体文件,如 audio,video,图片等,将相应的信息放到定义好的数据库表格中。在这个程序中,我们不需要关心如何去扫描手机中的文件,只要了解如何查询和使用 这些信息就可以了。
MediaStore中定义了一系列的数据表格,通过ContentResolver提供的查询接口,我们可以得到各种需要的信息。下面我们重点介绍如何管理SD卡上的音乐文件信息。
Cursor cursor = context.getContentResolver.query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder)
Uri:指明要查询的数据库名称加上表的名称,从MediaStore中我们可以找到相应信息的参数,具体请参考开发文档。
Projection: 指定查询数据库表中的哪几列,返回的游标中将包括相应的信息。Null则返回所有信息。
selection: 指定查询条件
selectionArgs:参数selection里有 ?这个符号是,这里可以以实际值代替这个问号。如果selection这个没有?的话,那么这个String数组可以为null。
SortOrder:指定查询结果的排列顺序
1.查询所有歌曲:
Cursor cursor = query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null ,
null , null , MediaStore.Audio.Media.DEFAULT_SORT_ORDER);
if(cursor == null){return;}
if(cursor.moveToFirst(){
do{
//MediaStore.Audio.Media.IS_MUSIC: 是否是音乐文件,返回0即为音乐媒体文件
Int isMusic = cursor.getInt(cursor.getColumnIndex(MediaStore.Audio.Media.IS_MUSIC));
//MediaStore.Audio.Media._ID:歌曲ID
Int id = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media._ID));
//MediaStore.Audio.Media.TITLE:歌曲的名称
String tilte = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.TITLE));
//MediaStore.Audio.Media.ALBUM :歌曲的专辑名
String album = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.ALBUM));
//MediaStore.Audio.Media.ARTIST:歌曲的歌手名
String artist = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.ARTIST));
//MediaStore.Audio.Media.DATA:歌曲文件的路径
String url = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.DATA));
//MediaStore.Audio.Media.DURATION:歌曲的总播放时长
Int duration = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.DURATION));
//MediaStore.Audio.Media.SIZE: 歌曲文件的大小
Int size = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.SIZE));
}while(cursor.moveToNext());
2.查询歌手信息:
Cursor cursor = query(MediaStore.Audio.Artists.EXTERNAL_CONTENT_URI, null , null , null ,
MediaStore.Audio.Artists.DEFAULT_SORT_ORDER);
该命令将返回所有在外部存储卡上的歌手信息,其中常用的信息如下:
if(cursor == null){return;}
if(cursor.moveToFirst(){
do{
//MediaStore.Audio.Artists._ID:歌手id
Int id = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Artists._ID));
//MediaStore.Audio.Artists.ARTIST :歌手姓名
String name = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Artists.ARTIST));
//MediaStore.Audio.Artists.NUMBER_OF_ALBUMS: 共有多少该歌手的专辑
Int numOfAlbum = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Artists.NUMBER_OF_ALBUMS));
//MediaStore.Audio.Artists.NUMBER_OF_TRACKS: 共有多少该歌手的歌曲
Int numOfSong = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Artists.NUMBER_OF_TRACKS));
}while(cursor.moveToNext());
3.查询专辑信息:
Cursor cursor = query(MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI, null , null , null ,
MediaStore.Audio.Albums.DEFAULT_SORT_ORDER);
该命令将返回所有在外部存储卡上的专辑信息,其中常用的信息如下:
if(cursor == null){return;}
if(cursor.moveToFirst(){
do{
//MediaStore.Audio.Albums._ID :专辑id
Int id = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Albums._ID));
//MediaStore.Audio.Albums.ALBUM:专辑名称
String name = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Albums.ALBUM));
//MediaStore.Audio.Albums.NUMBER_OF_SONGS:共用多少歌曲属于该专辑
Int numOfSong = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Albums.NUMBER_OF_SONGS));
}while(cursor.moveToNext());
4.查询播放列表:
Cursor cursor = query(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI, null , null , null ,
MediaStore.Audio.Playlists.DATE_ADDED + " asc" );
该命令将返回所有在外部存储卡上的专辑信息,其中常用的信息如下:
if(cursor == null){return;}
if(cursor.moveToFirst(){
do{
//MediaStore.Audio.Playlists._ID :播放列表id
Int id = cursor.getInt(cursor.getColumnIndexOrThrow(MediaStore.Audio.Playlists._ID));
//MediaStore.Audio.Playlists.NAME:播放列表名称
String name = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Playlists.NAME));
//MediaStore.Audio.Playlists.DATE_ADDED :添加时间
long dateAdded = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.Audio.Playlists.DATE_ADDED));
//MediaStore.Audio.Playlists.DATE_MODIFIED :修改时间
long dateModified = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.Audio.Playlists.DATE_MODIFIED));
}while(cursor.moveToNext());
通过组合这些查询结果,指定查询条件,用户可以很方便的查询指定的媒体信息,比如:查询属于指定歌手(歌手id 为 aid)的歌曲:
query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null ,
MediaStore.Audio.Media.ARTIST_ID + "=" + aid, null ,
MediaStore.Audio.Media.TITLE);
查询属于指定专辑(专辑id 为 aid)的歌曲:
return query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null ,
MediaStore.Audio.Media.ALBUM_ID + "=" + aid, null ,
MediaStore.Audio.Media.TITLE);
通过AlbumId查询出专辑封面Uri地址:
Cursor cursor = context.getContentResolver().query(Uri.parse("content://media/external/audio/albums/" + albumId), new String[]{"album_art"}, null, null, null);
if(cursor == null){return;}
if(cursor.moveToFirst(){
do{
uri = cursor.getString(0);
}while(cursor.moveToNext());