Android系统使用MediaFile类判断音频文件类型

上一篇文章Android实现sdcard音频文件浏览及播放说了sdcard文件浏览及使用MediaPlayer类播放音频文件,在判断文件类型是否为音频文件时,采用MediaFile类根据文件扩展名的简单方式来实现。 除了根据文件扩展名来判断文件类型外,还可以根据文件头信息来识别,不过这种方法要知道各种音频文件头的解析格式。比较复杂,暂时没去研究。下面看看MediaFile类,这个类根据需要对isAudioFileType进行重载,代码如下:


原文地址:Android系统使用MediaFile类判断音频文件类型 | http://orgcent.com/android-mediafile-audio-filetype/
发布了0 篇原创文章 · 获赞 1 · 访问量 5万+
展开阅读全文

Android Media数据库出错

08-07

开机启动音乐后,加载上次播放列表,并播放上次记录的音乐,在setDataSource播放的时候出错。Logcat如下: 25.675 E/DatabaseUtils( 695): java.lang.NullPointerException 01-01 02:22:25.675 E/DatabaseUtils( 695): at java.io.File.fixSlashes(File.java:185) 01-01 02:22:25.675 E/DatabaseUtils( 695): at java.io.File.<init>(File.java:134) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.queryForDataFile(MediaProvider.java:4734) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.openFileAndEnforcePathPermissionsHelper(MediaProvider.java:4754) 01-01 02:22:25.675 E/DatabaseUtils( 695): at com.android.providers.media.MediaProvider.openFile(MediaProvider.java:4680) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openAssetFile(ContentProvider.java:1213) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openTypedAssetFile(ContentProvider.java:1393) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider.openTypedAssetFile(ContentProvider.java:1459) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProvider$Transport.openTypedAssetFile(ContentProvider.java:342) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.content.ContentProviderNative.onTransact(ContentProviderNative.java:305) 01-01 02:22:25.675 E/DatabaseUtils( 695): at android.os.Binder.execTransact(Binder.java:404) 01-01 02:22:25.675 E/DatabaseUtils( 695): at dalvik.system.NativeStart.run(Native Method) 01-01 02:22:25.675 E/MediaPlaybackService( 995): mPlayer.setDataSource 01-01 02:22:25.675 W/System.err( 995): java.lang.NullPointerException 01-01 02:22:25.675 W/System.err( 995): at android.os.Parcel.readException(Parcel.java:1471) 01-01 02:22:25.675 W/System.err( 995): at android.database.DatabaseUtils.readExceptionFromParcel(DatabaseUtils.java:185) 01-01 02:22:25.675 W/System.err( 995): at android.database.DatabaseUtils.readExceptionWithFileNotFoundExceptionFromParcel(DatabaseUtils.java:148) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentProviderProxy.openTypedAssetFile(ContentProviderNative.java:682) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openTypedAssetFileDescriptor(ContentResolver.java:1063) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:904) 01-01 02:22:25.675 W/System.err( 995): at android.content.ContentResolver.openAssetFileDescriptor(ContentResolver.java:831) 01-01 02:22:25.675 W/System.err( 995): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:898) 01-01 02:22:25.675 W/System.err( 995): at android.media.MediaPlayer.setDataSource(MediaPlayer.java:874) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService$MultiPlayer.setDataSourceImpl(MediaPlaybackService.java:2213) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService$MultiPlayer.setDataSource(MediaPlaybackService.java:2200) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.open(MediaPlaybackService.java:1396) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.openCurrentAndNext(MediaPlaybackService.java:1280) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.reloadQueue(MediaPlaybackService.java:700) 01-01 02:22:25.675 W/System.err( 995): at com.android.newmusic.MediaPlaybackService.onCreate(MediaPlaybackService.java:444) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.handleCreateService(ActivityThread.java:2558) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.access$1800(ActivityThread.java:135) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278) 01-01 02:22:25.675 W/System.err( 995): at android.os.Handler.dispatchMessage(Handler.java:102) 01-01 02:22:25.675 W/System.err( 995): at android.os.Looper.loop(Looper.java:136) 01-01 02:22:25.675 W/System.err( 995): at android.app.ActivityThread.main(ActivityThread.java:5001) 01-01 02:22:25.675 W/System.err( 995): at java.lang.reflect.Method.invokeNative(Native Method) 01-01 02:22:25.675 W/System.err( 995): at java.lang.reflect.Method.invoke(Method.java:515) 01-01 02:22:25.675 W/System.err( 995): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:801) 01-01 02:22:25.675 W/System.err( 995): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:617) 01-01 02:22:25.675 W/System.err( 995): at dalvik.system.NativeStart.main(Native Method) 01-01 02:22:25.675 D/MediaPlaybackService( 995): Failed to open file for playback 问答

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 大白 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览