[轉]---Android獲取SD卡視頻音頻文件


獲取視頻文件:

 1         ContentResolver contentResolver = mContext.getContentResolver();
 2         String[] projection = new String[]{MediaStore.Video.Media.TITLE};
 3         Cursor cursor = contentResolver.query(MediaStore.Video.Media.EXTERNAL_CONTENT_URI, projection, 
 4                 null, null, MediaStore.Video.Media.DEFAULT_SORT_ORDER);
 5         cursor.moveToFirst();
 6         int fileNum = cursor.getCount();
 7        
 8         for(int counter = 0; counter < fileNum; counter++){        
 9             Log.w(TAG, "----------------------file is: " + cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.TITLE)) );
10 
11             cursor.moveToNext();
12         }
13         cursor.close();

 

         如果獲取路徑,需要講projection修改為String[] projection = new String[]{MediaStore.Video.Media.DATA};

         獲取的語句也需要修改為:cursor.getString(cursor.getColumnIndex(MediaStore.Video.Media.DATA));

獲取音頻文件:

             

 1         Cursor cursor = mContext.getContentResolver().query(MediaStore.Audio.Media.EXTERNAL_CONTENT_URI,
 2                 null, null, null, MediaStore.Audio.Media.DEFAULT_SORT_ORDER);
 3         cursor.moveToFirst();
 4         int counter = cursor.getCount();
 5         String title = cursor.getString(cursor.getColumnIndexOrThrow(MediaStore.Audio.Media.TITLE));
 6         
 7         Log.w(TAG, "------------before looping, title = " + title);
 8         for(int j = 0 ; j < counter; j++){
 9             Log.w(TAG, "-----------title = " + cursor.getString(cursor.getColumnIndex(MediaStore.Audio.Media.TITLE)));
10             cursor.moveToNext();
11         }
12         cursor.close();

 

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

首先給大家講android的多媒體數據庫。MediaStore這個類是android系統提供的一個多媒體數據庫,android中多媒體信息都可以從這里提取。這個MediaStore包括了多媒體數據庫的所有信息,包括音頻

,視頻和圖像,android把所有的多媒體數據庫接口進行了封裝,所有的數據庫不用自己進行創建,直接調用利用ContentResolver去掉用那些封裝好的接口就可以進行數據庫的操作了。今天我就介紹一些

這些接口的用法。

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

1 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語句來查看你想要的數據,記得最后一定要記住每條語句后面都加上分號。下面開始講述怎么在這些表上進行增刪改查。

查詢,代碼如下所示:

1 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,用法和它差不多。

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

增加,代碼如下所以:

1 ContentValues values = new ContentValues();
2 values.put(MediaStore.Audio.Playlists.Members.PLAY_ORDER,0);
3 resolver.insert(_uri, values);

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

法去插入就好了。

更新,代碼如下:

1 ContentResolver resolver = ctx.getContentResolver();
2 Uri uri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
3 ContentValues values = new ContentValues();
4 values.put(MediaStore.Audio.Media.DATE_MODIFIED, sid);
5 resolver.update(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,values, where, selectionArgs);

上面update方法和查詢還有增加里的參數都很類似,這里就不再重復敘述了,大家也可直接參考google的文檔,那里也寫的很清楚。

刪除,代碼如下:

1 ContentResolver resolver = ctx.getContentResolver();
2 resolver.delete(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,where, selectionArgs);

原文鏈接:http://hi.baidu.com/magicerror/item/db597e1166537d0bb98a1a88


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM