Android/读取指定类型的文件

public final class

MediaStore

extends  Object
java.lang.Object
   ↳ android.provider.MediaStore
The Media provider contains meta data for all available media on both internal and external storage devices.

tr: 媒体提供者 包含了外部存储以及内部存储中所有有效的媒体介质


工作中遇到的一个需求 :
获取 SDcard中 所有音频,视频,以及文本文档 进行备份

Nested Classes
class MediaStore.Audio | Container for all audio content.
class MediaStore.Files | Media provider table containing an index of all files in the media storage, including non-media files.
class MediaStore.Images| Contains meta data for all available images.
class MediaStore.Video | 



获取音频文件的一个范例:
(视频仅需更换Audio类为Video类)

int limit = 30;
		String[] iStrings = new String[limit];
		String[] audioItems = { MediaStore.Audio.Media.TITLE,
				MediaStore.Audio.Media.DURATION, MediaStore.Audio.Media.ARTIST,
				MediaStore.Audio.Media._ID,
				MediaStore.Audio.Media.DISPLAY_NAME,
				MediaStore.Audio.Media.DATA };

		Cursor audioCursor = GlobalVars.appContext.getContentResolver().query(
				MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, audioItems, null,
				null, MediaStore.Audio.Media._ID + "");
		if (audioCursor != null) {
			audioCursor.moveToFirst();
			int i = 0;
			while (audioCursor.getPosition() != audioCursor.getCount()
					&& i < limit) {
				Uri uri = Uri.parse(audioCursor.getString(audioCursor
						.getColumnIndex(MediaStore.Audio.Media.DATA)));
				iStrings[i] = uri.getPath();
				audioCursor.moveToNext();
				i++;
			}
			audioCursor.close();
		}


这里需要注意的是 当使用的API < 11 (3.0)时, 是不支持 MediaStore.Files 类的
所以在 3.0之前 ,还是需要用遍历的方式! 

	// FIXME 临时设定文档的类型
	public static final String[] documentTypeArr = { ".txt", ".pdf" };

	private List<File> getDocumentsFiles(File root) {
		File files[] = root.listFiles();
		if (files != null)
			for (File f : files) {
				if (f.isDirectory()) {
					getDocumentsFiles(f);
				} else {
					if (isVaildFileType(f))
						this.list.add(f);
				}
			}
		return list;
	}

	private boolean isVaildFileType(File f) {

		for (String type : documentTypeArr) {
			if (f.getName().contains(type))
				return true;
		}
		return false;
	}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值