android如何獲取SD卡上的多媒體文件

獲取視頻文件: html

        ContentResolver contentResolver = mContext.getContentResolver();
        String[] projection = new String[]{MediaStore.Video.Media.TITLE};
        Cursor cursor = contentResolver.query(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, projection, 
                null, null, MediaStore.Video.Media.DEFAULT_SORT_ORDER);
        cursor.moveToFirst();
        int fileNum = cursor.getCount();
       
        for(int counter = 0; counter < fileNum; counter++){        
            Log.w(TAG, "----------------------file is: " + cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.TITLE)) ); android

            cursor.moveToNext();
        }
        cursor.close(); sql

         若是獲取路徑,須要講projection修改成String[] projection = new String[]{MediaStore.Video.Media.DATA}; shell

         獲取的語句也須要修改成:cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.DATA)); 數據庫

獲取音頻文件: 數組

            Cursor cursor = mContext.getContentResolver().query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI,
                    null, null, null, MediaStore.Audio.Media.DEFAULT_SORT_ORDER);
            cursor.moveToFirst();
            int counter = cursor.getCount();
            String title = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.TITLE));
            
            Log.w(TAG, "------------before looping, title = " + title);
            for(int j = 0 ; j < counter; j++){
                Log.w(TAG, "-----------title = "
                        + cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.TITLE)));
                
                        cursor.moveToNext();
                
            }
            cursor.close(); 網絡

如下內容來自網絡http://blog.sina.com.cn/s/blog_5be1061c0100ctco.html ide

首先給你們講android的多媒體數據庫。MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息均可以從這裏提取。這個MediaStore包括了多媒體數據庫的全部信息,包括音頻 oop

,視頻和圖像,android把全部的多媒體數據庫接口進行了封裝,全部的數據庫不用本身進行建立,直接調用利用ContentResolver去掉用那些封裝好的接口就能夠進行數據庫的操做了。今天我就介紹一些 this

這些接口的用法。

首先,要獲得一個ContentResolver實例,ContentResolver能夠這樣獲取,利用一個Activity或者Service的Context便可。以下所示:

ContentResolver mResolver = ctx.getContentResolver();

上面的那個ctx的就是一個context,Activity.this就是那個Context,這個Context就至關於一個上下文環境。獲得這個Context後就能夠調用getContentResolver接口獲取ContentResolver實例了。

ContentResolver實例得到後,就能夠進行各類查詢,下面我就以音頻數據庫爲例講解增刪改查的方法,視頻和圖像和音頻很是相似。

在講解各類查詢以前,我給你們介紹下怎麼看android都提供了哪些多媒體表。在adb shell中,找到/data/data/com.android.providers.media/databases/下,而後找到SD卡的數據庫文件(通常是

一個.db文件),而後輸入命令sqlite3加上這個數據庫的名字就能夠查詢android的多媒體數據庫了。.table命令能夠列出全部多媒體數據庫的表,.scheme加上表名能夠查詢表中的全部列名。這裏能夠利

用SQL語句來查看你想要的數據,記得最後必定要記住每條語句後面都加上分號。下面開始講述怎麼在這些表上進行增刪改查。

查詢,代碼以下所示:

Cursor cursor = resolver.query(_uri, prjs, selections, selectArgs, order);

ContentResolver的query方法接受幾個參數,參數意義以下:

Uri:這個Uri表明要查詢的數據庫名稱加上表的名稱。這個Uri通常都直接從MediaStore裏取得,例如我要取全部歌的信息,就必須利用MediaStore.Audio.Media. EXTERNAL _CONTENT_URI這個Uri。

專輯信息要利用MediaStore.Audio.Albums.EXTERNAL_CONTENT_URI這個Uri來查詢,其餘查詢也都相似。

Prjs:這個參數表明要從表中選擇的列,用一個String數組來表示。

Selections:至關於SQL語句中的where子句,就是表明你的查詢條件。

selectArgs:這個參數是說你的Selections裏有?這個符號是,這裏能夠以實際值代替這個問號。若是Selections這個沒有?的話,那麼這個String數組能夠爲null。

Order:說明查詢結果按什麼來排序。

上面就是各個參數的意義,它返回的查詢結果一個Cursor,這個Cursor就至關於數據庫查詢的中Result,用法和它差很少。

-------------------------------------------------------------------------------------------------------------------

增長,代碼以下因此:

ContentValues values = new ContentValues();

values.put(MediaStore.Audio.Playlists.Members.PLAY_ORDER,0);

resolver.insert(_uri, values);

這個insert傳遞的參數只有兩個,一個是Uri(同查詢那個Uri),另外一個是ContentValues。這個ContentValuses對應於數據庫的一行數據,只要用put方法把每一個列的設置好以後,直接利用insert方

法去插入就行了。

更新,代碼以下:

ContentResolver resolver = ctx.getContentResolver();

Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;

ContentValues values = new ContentValues();

values.put(MediaStore.Audio.Media.DATE_MODIFIED, sid);

resolver.update(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,values, where, selectionArgs);

上面update方法和查詢還有增長裏的參數都很相似,這裏就再也不重複敘述了,你們也可直接參考google的文檔,那裏也寫的很清楚。

刪除,代碼以下:

ContentResolver resolver = ctx.getContentResolver();

nbsp;   resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);

相關文章
相關標籤/搜索