【Android开发】之MediaPlayer的错误分析

 

 

  最近在作媒体播放器,使用了Android自带的MediaPlayer,常常性会碰到MediaPlayer报错的状况,找过网上的,感受总结的不是很好或者比较散。下面,我来总结一下使用MediaPlayer常常会出现的错误。若是有比较了解的,也能够在下面评论探讨一下。html

 

  1、Mediaplayer简介

    Mediaplayer能够用来控制音频或者视频文件、流的播放。(MediaPlayer class can be used to control playback of audio/video files and streams. )android

这里是Android的官方API关于Mediaplayer的介绍:http://developers.androidcn.com/reference/android/media/MediaPlayer.html编程

    在官方API中,咱们能够看到Mediaplayer的生命周期图:在这个生命周期图中,咱们能够看到Mediaplayer的一些调用、状态等状况。异步

      

 

 

  2、常见的错误分析

    1.最多见的错误(-38,0):

      a.若是初始化MediaPlayer经过create方法设置数据源。则不能写MediaPlayer.prepare()方法,不然会报错。ide

      b.若是是使用MediaPlayer构造函数初始化MediaPlayer,而后经过setDataSource方法设置数据源时,就须要将MediaPlayer.start()方法写在MediaPlayer的OnPrepared函数里面(缘由是音频文件没有准备好):以下面的代码函数

1 mediaPlayer.setOnPreparedListener(new OnPreparedListener() {
2                 @Override
3                 public void onPrepared(MediaPlayer mp) {
4                     mp.start();
5                 }
6             });

      c.若是是apk里,写好的文件。可能还须要"chmod 777”修复一下权限。关于这个解决方案,我不是很了解,有懂得能够说一下。spa

 

    2.其余的错误:

      咱们能够经过对MediaPlayer设置onErrorListener来监听错误代码。例如(-38,0)的错误,就是如下面的形式出现的(what,extra),下面给出了部分的错误和对应的错误信息提示(从stackoverflow找到的)。.net

 1 mediaPlayer.setOnErrorListener(new OnErrorListener() {
 2                 @Override
 3                 public boolean onError(MediaPlayer mp, int what, int extra) {
 4                     Log.d(TAG, "OnError - Error code: " + what + " Extra code: " + extra);
 5                     switch (what) {
 6                     case -1004:
 7                         Log.d(TAG, "MEDIA_ERROR_IO");
 8                         break;
 9                     case -1007:
10                         Log.d(TAG, "MEDIA_ERROR_MALFORMED");
11                         break;
12                     case 200:
13                         Log.d(TAG, "MEDIA_ERROR_NOT_VALID_FOR_PROGRESSIVE_PLAYBACK");
14                         break;
15                     case 100:
16                         Log.d(TAG, "MEDIA_ERROR_SERVER_DIED");
17                         break;
18                     case -110:
19                         Log.d(TAG, "MEDIA_ERROR_TIMED_OUT");
20                         break;
21                     case 1:
22                         Log.d(TAG, "MEDIA_ERROR_UNKNOWN");
23                         break;
24                     case -1010:
25                         Log.d(TAG, "MEDIA_ERROR_UNSUPPORTED");
26                         break;
27                     }
28                     switch (extra) {
29                     case 800:
30                         Log.d(TAG, "MEDIA_INFO_BAD_INTERLEAVING");
31                         break;
32                     case 702:
33                         Log.d(TAG, "MEDIA_INFO_BUFFERING_END");
34                         break;
35                     case 701:
36                         Log.d(TAG, "MEDIA_INFO_METADATA_UPDATE");
37                         break;
38                     case 802:
39                         Log.d(TAG, "MEDIA_INFO_METADATA_UPDATE");
40                         break;
41                     case 801:
42                         Log.d(TAG, "MEDIA_INFO_NOT_SEEKABLE");
43                         break;
44                     case 1:
45                         Log.d(TAG, "MEDIA_INFO_UNKNOWN");
46                         break;
47                     case 3:
48                         Log.d(TAG, "MEDIA_INFO_VIDEO_RENDERING_START");
49                         break;
50                     case 700:
51                         Log.d(TAG, "MEDIA_INFO_VIDEO_TRACK_LAGGING");
52                         break;
53                     }
54                     return false;
55                 }
56             });

    

    3.错误状态:

      也就是这样的错误 start called in state 0,0表示他的错误状态,下面是MediaPlayer的状态,源码中找到的:线程

 1 enum media_player_states {
 2         MEDIA_PLAYER_STATE_ERROR        = 0,
 3         MEDIA_PLAYER_IDLE                = 1 << 0, // 1
 4         MEDIA_PLAYER_INITIALIZED        = 1 << 1, // 2
 5         MEDIA_PLAYER_PREPARING            = 1 << 2, // 4
 6         MEDIA_PLAYER_PREPARED            = 1 << 3, // 8
 7         MEDIA_PLAYER_STARTED            = 1 << 4, // 16
 8         MEDIA_PLAYER_PAUSED                = 1 << 5, // 32
 9         MEDIA_PLAYER_STOPPED            = 1 << 6, // 64
10         MEDIA_PLAYER_PLAYBACK_COMPLETE  = 1 << 7, // 128
11 };

      能够参照报错的状态和MediaPlayer的生命周期(上图)进行错误分析。code

 

  3、一些建议

    1.在使用MediaPlayer准备的时候,最好使用prepareAsync()方法,而不是prepare()方法,由于前一个方法是异步准备的,不会阻碍主线程;

    2.mediaplayer.start()方法最好写到setOnPreparedListener的onPrepared函数中启动;虽然有时候prepareAsync()/prepare()以后直接写start方法也不会报错,可是咱们要消除这个bug!!

    3.当中止播放MediaPlayer后,必定要再次调用MediaPlayer的prepareAsync()方法,而不能直接调用start()方法!从上面的MediaPlayer生命周期中能够看到。

    4.经过设置监听器,并本身设置变量来标记MediaPlayer的大概状态(特别是Error,End,Idle),在操做相关的函数前先检测下,就能避免大多数"操做错误"。再不行就每一个MediaPlayer的函数操做都加上对IllegalStateException异常的捕获

    5.在咱们编程中,咱们能够一步一步的参照MediaPlayer的生命周期去编写。这样就能够减小不少错误的发生。

 

 

  感谢你们的阅读,可能还有一些不完善的地方,同窗们有了解的能够再下面留言,我能够完善Mediaplayer供你们参考。若是有须要能够订阅一下,期待下一个博客!个人CSDN博客:http://blog.csdn.net/u010049692/article/details/38867449

相关文章
相关标签/搜索