查询图片
首先,查询Android固有数据库,图片的Uri为Images.Media.EXTERNAL_CONTENT_URI
。
以下为具体查询实例,FileInfo
为自定义的数据模型。
public ArrayList<FileInfo> queryAllImage(final Context context) {
if (context == null) { //判断传入的参数的有效性
return null;
}
ArrayList<FileInfo> images = new ArrayList<FileInfo>();
ContentResolver resolver = context.getContentResolver();
Cursor cursor = null;
try {
//查询数据库,参数分别为(路径,要查询的列名,条件语句,条件参数,排序)
cursor = resolver.query(Images.Media.EXTERNAL_CONTENT_URI, null, null ,null, null);
if (cursor != null) {
while (cursor.moveToNext()) {
FileInfo image = new FileInfo();
image.setId(cursor.getInt(cursor.getColumnIndex(Images.Media._ID))); //获取唯一id
image.setFilePath(cursor.getString(cursor.getColumnIndex(Images.Media.DATA))); //文件路径
image.setFileName(cursor.getString(cursor.getColumnIndex(Images.Media.DISPLAY_NAME))); //文件名
//... 还有很多属性可以设置
//可以通过下一行查看属性名,然后在Images.Media.里寻找对应常量名
Log.i(TAG, "queryAllImage --- all column name --- " + cursor.getColumnName(cursor.getPosition()));
//获取缩略图(如果数据量大的话,会很耗时——需要考虑如何开辟子线程加载)
/*
* 可以访问android.provider.MediaStore.Images.Thumbnails查询图片缩略图
* Thumbnails下的getThumbnail方法可以获得图片缩略图,其中第三个参数类型还可以选择MINI_KIND
*/
Bitmap thumbnail = MediaStore.Images.Thumbnails.getThumbnail(resolver, image.getId(), Images.Thumbnails.MICRO_KIND, null);
image.setThumbnail(thumbnail);
images.add(image);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (cursor != null) {
cursor.close();
}
}
return images;
}
查询音频
也是先查询数据库获得音频相关信息,音频的Uri为Audio.Media.EXTERNAL_CONTENT_URI
以下为具体查询实例,FileInfo
为自定义的数据模型。
public ArrayList<FileInfo> queryAllAudio(final Context context) {
if (context == null) { //判断传入的参数的有效性
return null;
}
ArrayList<FileInfo> audios = new ArrayList<FileInfo>();
ContentResolver resolver = context.getContentResolver();
Cursor cursor = null;
try {
//查询数据库,参数分别为(路径,要查询的列名,条件语句,条件参数,排序)
cursor = resolver.query(Audio.Media.EXTERNAL_CONTENT_URI, null, null ,null, null);
if (cursor != null) {
while (cursor.moveToNext()) {
FileInfo audio = new FileInfo();
audio.setId(cursor.getInt(cursor.getColumnIndex(Audio.Media._ID))); //获取唯一id
audio.setFilePath(cursor.getString(cursor.getColumnIndex(Audio.Media.DATA))); //文件路径
audio.setFileName(cursor.getString(cursor.getColumnIndex(Audio.Media.DISPLAY_NAME))); //文件名
//... 还有很多属性可以设置
//可以通过下一行查看属性名,然后去Audio.Media里寻找对应常量名
Log.i(TAG, "queryAllImage --- all column name --- " + cursor.getColumnName(cursor.getPosition()));
//获取专辑封面(如果数据量大的话,会很耗时——需要考虑如何开辟子线程加载)
Bitmap albumArt = creatAlbumArt(audio.getFilePath());
audio.setThumbnail(albumArt);
audios.add(audio);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (cursor != null) {
cursor.close();
}
}
return audios;
}
/**
* @Description 获取专辑封面
* @param filePath 文件路径,like XXX/XXX/XX.mp3
* @return 专辑封面bitmap
*/
public Bitmap createAlbumArt(final String filePath) {
Bitmap bitmap = null;
//能够获取多媒体文件元数据的类
MediaMetadataRetriever retriever = new MediaMetadataRetriever();
try {
retriever.setDataSource(filePath); //设置数据源
byte[] embedPic = retriever.getEmbeddedPicture(); //得到字节型数据
bitmap = BitmapFactory.decodeByteArray(art, 0, art.length); //转换为图片
} catch (Exception e) {
e.printStackTrace();
} finally {
try {
retriever.release();
} catch (Exception e2) {
e2.printStackTrace();
}
}
return bitmap;
}
查询视频
查询视频缩略图的方法和图片的很像。
以下为具体查询实例,FileInfo
为自定义的数据模型。
public ArrayList<FileInfo> queryAllVideo(final Context context) {
if (context == null) { //判断传入的参数的有效性
return null;
}
ArrayList<FileInfo> videos = new ArrayList<FileInfo>();
ContentResolver resolver = context.getContentResolver();
Cursor cursor = null;
try {
//查询数据库,参数分别为(路径,要查询的列名,条件语句,条件参数,排序)
cursor = resolver.query(Video.Media.EXTERNAL_CONTENT_URI, null, null ,null, null);
if (cursor != null) {
while (cursor.moveToNext()) {
FileInfo video = new FileInfo();
video.setId(cursor.getInt(cursor.getColumnIndex(Video.Media._ID))); //获取唯一id
video.setFilePath(cursor.getString(cursor.getColumnIndex(Video.Media.DATA))); //文件路径
video.setFileName(cursor.getString(cursor.getColumnIndex(Video.Media.DISPLAY_NAME))); //文件名
//... 还有很多属性可以设置
//可以通过下一行查看属性名,然后在Video.Media.里寻找对应常量名
Log.i(TAG, "queryAllImage --- all column name --- " + cursor.getColumnName(cursor.getPosition()));
//获取缩略图(如果数据量大的话,会很耗时——需要考虑如何开辟子线程加载)
/*
* 可以访问android.provider.MediaStore.Video.Thumbnails查询图片缩略图
* Thumbnails下的getThumbnail方法可以获得图片缩略图,其中第三个参数类型还可以选择MINI_KIND
*/
Bitmap thumbnail = MediaStore.Video.Thumbnails.getThumbnail(resolver, image.getId(), Video.Thumbnails.MICRO_KIND, null);
video.setThumbnail(thumbnail);
videos.add(image);
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
if (cursor != null) {
cursor.close();
}
}
return videos;
}
以上方法经个人实践有效,如果你有任何问题,请留言告诉我。
时间: 2024-10-06 19:53:23