Android获取SD卡视频音频文件

Android获取SD卡视频音频文件



获取视频文件:

 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)) );



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

         若是获取路径,须要将projection批改为String[] projection = new String[]{MediaStore.Video.Media.DATA};


         获取的语句也须要批改为: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


起首给大师讲android的多媒体数据库。MediaStore这个类是android体系供给的一个多媒体数据库,android中多媒体信息都可以从这里提取。这个MediaStore包含了多媒体数据库的所有信息,包含音频


,视频和图像,android把所有的多媒体数据库接口进行了封装,所有的数据库不消本身进行创建,直接调用哄骗ContentResolver去掉用那些封装好的接口就可以进行数据库的操纵了。今天我就介绍一些


这些接口的用法。


起首,要获得一个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, ions, Args, 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子句,就是代表你的查询前提。


Args:这个参数是说你的Selections里有?这个符号是,这里可以以实际值庖代这个问号。若是Selections这个没有?的话,那么这个String数组可认为null。


Order:申明查询成果按什么来排序。


上方就是各个参数的意义,它返回的查询成果一个Cursor,这个Cursor就相当于数据库查询的中Result,用法和它差不久不多。


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


增长,代码如下所以:


ContentValues values = new ContentValues();


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


resolver.(_uri, values);


这个传递的参数只有两个,一个是Uri(同查询那个Uri),另一个是ContentValues。这个ContentValuses对应于数据库的一行数据,只要用put办法把每个列的设置好之后,直接哄骗方


法去插入就好了。


更新,代码如下:


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.(MediaStore.Audio.Playlists.EXTERNAL_CONTENT_URI,values, where, ionArgs);


上方办法和查询还有增长里的参数都很类似,这里就不再反复论述了,大师也可直接参考google的文档,那边也写的很清楚。


删除,代码如下:


ContentResolver resolver = ctx.getContentResolver();


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


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值