Android開發(fā) 多媒體信息數(shù)據(jù)庫(MediaStore 僅作記錄)

一挂脑、MediaStore簡介

MediaStore是android系統(tǒng)提供的一個多媒體數(shù)據(jù)庫宠页,專門用于存放多媒體信息的胁塞,通過ContentResolver即可對數(shù)據(jù)庫進行操作碘举。

MediaStore.Files: 共享的文件,包括多媒體和非多媒體信息

MediaStore.Audio: 存放音頻信息

MediaStore.Image: 存放圖片信息

MediaStore.Vedio: 存放視頻信息

每個內(nèi)部類中都又包含了Media,Thumbnails和相應的MediaColumns格侯,分別提供了媒體信息岭辣,縮略信息和 操作字段吱晒。

二、MediaStore使用

都是通過 ContentResolver 和 Cursor 來操作的沦童。

2.1仑濒、MediaStore.Files

2.1.1叹话、查詢所有類型文件

/**
 * 獲取所有文件
 **/
public static List<FileEntity> getFilesByType(Context context) {
    List<FileEntity> files = new ArrayList<>();
    // 掃描files文件庫
    Cursor c = null;
    try {
        mContentResolver = context.getContentResolver();
        c = mContentResolver.query(MediaStore.Files.getContentUri("external"), null, null, null, null);
        int columnIndexOrThrow_ID = c.getColumnIndexOrThrow(MediaStore.Files.FileColumns._ID);
        int columnIndexOrThrow_MIME_TYPE = c.getColumnIndexOrThrow(MediaStore.Files.FileColumns.MIME_TYPE);
        int columnIndexOrThrow_DATA = c.getColumnIndexOrThrow(MediaStore.Files.FileColumns.DATA);
        int columnIndexOrThrow_SIZE = c.getColumnIndexOrThrow(MediaStore.Files.FileColumns.SIZE);
        // 更改時間
        int columnIndexOrThrow_DATE_MODIFIED = c.getColumnIndexOrThrow(MediaStore.Files.FileColumns.DATE_MODIFIED); 

        int tempId = 0;
        while (c.moveToNext()) {
            String path = c.getString(columnIndexOrThrow_DATA);
            String minType = c.getString(columnIndexOrThrow_MIME_TYPE);
            LogUtil.d("FileManager", "path:" + path);
            int position_do = path.lastIndexOf(".");
            if (position_do == -1) {
                continue;
            }
            int position_x = path.lastIndexOf(File.separator);
            if (position_x == -1) {
                continue;
            }
            String displayName = path.substring(position_x + 1, path.length());
            long size = c.getLong(columnIndexOrThrow_SIZE);
            long modified_date = c.getLong(columnIndexOrThrow_DATE_MODIFIED);
            File file = new File(path);
            String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date(file.lastModified()));
            FileEntity info = new FileEntity();
            info.setName(displayName);
            info.setPath(path);
            info.setSize(ShowLongFileSzie(size));
            info.setId((tempId++) + "");
            info.setTime(time);
            files.add(info);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        if (c != null) {
            c.close();
        }
    }
    return files;
}

2.1.2、指定獲取的文件字段

String[] columns = new String[]{MediaStore.Files.FileColumns._ID, MediaStore.Files.FileColumns.MIME_TYPE, MediaStore.Files.FileColumns
            .SIZE, MediaStore.Files.FileColumns.DATE_MODIFIED, MediaStore.Files.FileColumns.DATA};
c = mContentResolver.query(MediaStore.Files.getContentUri("external"), columns, null, null, null);

2.1.3墩瞳、根據(jù)文件夾的名稱查詢

//查找文件夾ScreenRecord下的文件
c = mContentResolver.query(MediaStore.Files.getContentUri("external"), null, MediaStore.Video.Media.BUCKET_DISPLAY_NAME+"=?", "ScreenRecord", null);

2.1.4驼壶、查詢指定類型的文件

String select = "(" + MediaStore.Files.FileColumns.DATA + " LIKE '%.doc'" + " or " + MediaStore.Files.FileColumns.DATA + " LIKE '%.docx'" + ")";
c = mContentResolver.query(MediaStore.Files.getContentUri("external"), null, select , null, null);

2.1.5、指定排序類型喉酌,如根據(jù)id倒序查詢

c = mContentResolver.query(MediaStore.Files.getContentUri("external"), null, null, null, MediaStore.Files.FileColumns._ID+"DESC");

2.2歉井、MediaStore.Audio
2.2.1挟纱、查詢音頻文件

c = mContentResolver.query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI, null, null, null, null);

2.3、MediaStore.Image
2.3.1、查詢圖片文件

c = mContentResolver.query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, null, null, null, null);

2.4虚茶、MediaStore.Vedio
2.4.1、查詢視頻文件

/**
 * 獲取視頻文件
 **/
public static List<FileEntity> getFilesByVideo(Context context) {
    List<FileEntity> files = new ArrayList<>();
    // 掃描files文件庫
    Cursor c = null;
    try {
        mContentResolver = context.getContentResolver();
        c = mContentResolver.query(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, null, null, null, null);
        int columnIndexOrThrow_ID = c.getColumnIndexOrThrow(MediaStore.Video.Media._ID);
        int columnIndexOrThrow_MIME_TYPE = c.getColumnIndexOrThrow(MediaStore.Video.Media.MIME_TYPE);
        int columnIndexOrThrow_DATA = c.getColumnIndexOrThrow(MediaStore.Video.Media.DATA);
        int columnIndexOrThrow_SIZE = c.getColumnIndexOrThrow(MediaStore.Video.Media.SIZE);
        // 更改時間
        int columnIndexOrThrow_DATE_MODIFIED = c.getColumnIndexOrThrow(MediaStore.Video.Media.DATE_MODIFIED); 

        int tempId = 0;
        while (c.moveToNext()) {
            String path = c.getString(columnIndexOrThrow_DATA);
            String minType = c.getString(columnIndexOrThrow_MIME_TYPE);
            LogUtil.d("FileManager", "path:" + path);
            int position_do = path.lastIndexOf(".");
            if (position_do == -1) {
                continue;
            }
            int position_x = path.lastIndexOf(File.separator);
            if (position_x == -1) {
                continue;
            }
            String displayName = path.substring(position_x + 1, path.length());
            long size = c.getLong(columnIndexOrThrow_SIZE);
            long modified_date = c.getLong(columnIndexOrThrow_DATE_MODIFIED);
            File file = new File(path);
            String time = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date(file.lastModified()));
            FileEntity info = new FileEntity();
            info.setName(displayName);
            info.setPath(path);
            info.setSize(ShowLongFileSzie(size));
            info.setId((tempId++) + "");
            info.setTime(time);
            files.add(info);
        }
    } catch (Exception e) {
        e.printStackTrace();
    } finally {
        if (c != null) {
            c.close();
        }
    }
    return files;
}

2.5秩彤、query()參數(shù)解析:

public final Cursor query(
Uri uri,                //數(shù)據(jù)資源路徑
String[] projection,    //查詢的列
String selection,       //查詢的條件
String[] selectionArgs, //條件填充值
String sortOrder){}     //排序依據(jù)

2.6肛冶、數(shù)據(jù)庫字段
MediaStore 提供了所有數(shù)據(jù)庫中的字段宏定義,操作起來十分方便。

比如:

INTERNAL_CONTENT_URI; //內(nèi)部庫URI
EXTERNAL_CONTENT_URI; //外部庫URI
CONTENT_TYPE; //內(nèi)容提供者類型
DEFAULT_SORT_ORDER; //排序方式

MediaStore.Files沒有EXTERNAL_CONTENT_URI突诬,所以只能用getContentUri()自行獲取苫拍,得出的URI其實是Uri.parse("content://media/external/files")

這個不難理解,以MediaStore.Images.Media為例攒霹,其URI有三種寫法:

Uri uri1 = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
Uri uri2 = MediaStore.Images.Media.getContentUri("external");
Uri uri3 = Uri.parse("content://media/external/images/media");
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末怯疤,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子催束,更是在濱河造成了極大的恐慌集峦,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抠刺,死亡現(xiàn)場離奇詭異塔淤,居然都是意外死亡,警方通過查閱死者的電腦和手機速妖,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門高蜂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人罕容,你說我怎么就攤上這事备恤。” “怎么了锦秒?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵露泊,是天一觀的道長。 經(jīng)常有香客問我旅择,道長惭笑,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮沉噩,結(jié)果婚禮上捺宗,老公的妹妹穿的比我還像新娘。我一直安慰自己川蒙,他們只是感情好蚜厉,可當我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著派歌,像睡著了一般弯囊。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上胶果,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天匾嘱,我揣著相機與錄音,去河邊找鬼早抠。 笑死霎烙,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的蕊连。 我是一名探鬼主播悬垃,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼甘苍!你這毒婦竟也來了尝蠕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤载庭,失蹤者是張志新(化名)和其女友劉穎看彼,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體囚聚,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡靖榕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了顽铸。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片茁计。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖谓松,靈堂內(nèi)的尸體忽然破棺而出星压,到底是詐尸還是另有隱情,我是刑警寧澤鬼譬,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布娜膘,位于F島的核電站,受9級特大地震影響拧簸,放射性物質(zhì)發(fā)生泄漏劲绪。R本人自食惡果不足惜男窟,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一盆赤、第九天 我趴在偏房一處隱蔽的房頂上張望贾富。 院中可真熱鬧,春花似錦牺六、人聲如沸颤枪。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽畏纲。三九已至,卻和暖如春春缕,著一層夾襖步出監(jiān)牢的瞬間盗胀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工锄贼, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留票灰,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓宅荤,卻偏偏與公主長得像屑迂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子冯键,可洞房花燭夜當晚...
    茶點故事閱讀 44,933評論 2 355