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

2024-05-04 16:08

本文主要是介绍【Android开发】之MediaPlayer的错误分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

  最近在做媒体播放器,使用了Android自带的MediaPlayer,经常性会碰到MediaPlayer报错的情况,找过网上的,感觉总结的不是很好或者比较散。下面,我来总结一下使用MediaPlayer经常会出现的错误。如果有比较了解的,也可以在下面评论探讨一下。

 

  一、Mediaplayer简介

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

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

    在官方API中,我们可以看到Mediaplayer的生命周期图:在这个生命周期图中,我们可以看到Mediaplayer的一些调用、状态等情况。

      

 

 

  二、常见的错误分析

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

      a.如果初始化MediaPlayer通过create方法设置数据源。则不能写MediaPlayer.prepare()方法,否则会报错。

      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”修复一下权限。关于这个解决方案,我不是很了解,有懂得可以说一下。

 

    2.其他的错误:

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

复制代码
 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的生命周期(上图)进行错误分析。

 

  三、一些建议

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

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

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

    4.在我们编程中,我们可以一步一步的参照MediaPlayer的生命周期去编写。这样就可以减少很多错误的发生。

 

 

  感谢大家的阅读,可能还有一些不完善的地方,同学们有了解的可以再下面留言,我可以完善Mediaplayer供大家参考。如果有需要可以订阅一下,期待下一个博客!我的博客园地址:http://www.cnblogs.com/getherBlog/p/3939033.html

这篇关于【Android开发】之MediaPlayer的错误分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/959587

相关文章

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

python中Hash使用场景分析

《python中Hash使用场景分析》Python的hash()函数用于获取对象哈希值,常用于字典和集合,不可变类型可哈希,可变类型不可,常见算法包括除法、乘法、平方取中和随机数哈希,各有优缺点,需根... 目录python中的 Hash除法哈希算法乘法哈希算法平方取中法随机数哈希算法小结在Python中,

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

关于MyISAM和InnoDB对比分析

《关于MyISAM和InnoDB对比分析》:本文主要介绍关于MyISAM和InnoDB对比分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录开篇:从交通规则看存储引擎选择理解存储引擎的基本概念技术原理对比1. 事务支持:ACID的守护者2. 锁机制:并发控制的艺