我是靠谱客的博主 缥缈母鸡,最近开发中收集的这篇文章主要介绍MediaPlayer使用常见问题Valid and invalid states常见问题讨论,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

  • 视频播放有声音没图像。
  • 视频图像变形。
  • 切入后台后声音还在继续播放。
  • 切入后台再切回来,视频黑屏。
  • 暂停后切入后台,再切回来,并保持暂停状态会黑屏,seekTo也没有用。
  • 播放时会有一小段时间的黑屏。
  • 多个SurfaceView用来播放视频,滑动切换时会有上个视频的残影。

等等一些其他更多问题。最为典型的应该就是上述这些问题了。这些问题,仔细看看官网上对于MediaPlayer的讲解后,基本都不会是问题。恩,最后一个问题除外。相对MediaPlayer的状态机来说,MediaPlayer的各个方法的有效状态和无效状态为我们在使用MediaPlayer的具体方法时,提供了更好的指南。

Valid and invalid states

感觉用有效状态和无效状态来翻译不太合适,干脆直接就用官方上面所说的Valid and invalid states吧。它指出了MediaPlayer中常用公有方法在那些状态下可以使用,在那些状态下不可以使用。 
我们可以将所有的方法分为三类。 
- 在任何状态下都可以使用的。比如设置监听,以及其他MediaPlayer中与资源无关的方法。需要特别注意的是setDisplay和setSurface两个方法。 
- 在MediaPlayer状态机中除Error状态都可以使用的。比如获取视频宽高、获取当前位置等。 
- 对状态有诸多限制,需要严格遵循状态机流程的方法。 比如start、pause、stop等等方法。 
具体的在MediaPlayer官方说明中有对应的表。

常见问题讨论

针对上面提到的问题,通过MediaPlayer的状态机和它的常用方法的可用状态来进行讨论,我们就能找到相应的原因,因为代码是不会欺骗的。 
1. 有声音没有图像 
视频播放有声音没图像也许是在使用MediaPlayer最容易出现的问题,几乎所有使用MediaPlayer的新手都会遇到。视频播放的图像呈现需要一个载体,需要利用MediaPlayer.setDisplay设置一个展示视频画面的SurfaceHolder,最终视频的每一帧图像是要绘制在Surface上面的。通常,设置给MediaPlayer的SurfaceHolder未被创建,视频播放就注定没有图像。 
* 比如你先调用了setDisplay,但是这个时候holder是没有被创建的。视频就没有图像了。 
* 或者你在setDisplay的时候holder确保了holder是被创建了,但是当因为一些原因holder被销毁了,视频也就没有图像了。 
* 再者,你没有给展示视频的view设置合适的大小,比如都设置wrap_content,或者都设置0,也会导致SurfaceHolder不能被创建,视频也就没有图像了。 
2. 视频图像变形 
Surface展示视频图像的时候,是不会去主动保证和呈现出来的图像和原始图像的宽高比例是一致的,所以我们需要自己去设置展示视频的View的宽高,以保证视频图像展示出来的时候不会变形。我认为比较合适的做法就是利用FrameLayout嵌套一个SurfaceView或者其他拥有Surface的View来作为视频图像播放的载体View,然后再OnVideoSizeChangeListener的监听回调中,对载体View的大小做更改。 
3. 切入后台后声音还在继续播放 
这个问题只需要在onPause中暂停播放即可 
4. 切入后台再切回来,视频黑屏 
诸如此类的黑屏问题,多是因为surfaceholder被销毁了,再切回来时,需要重新给MediaPlayer设置holder。 
5. 播放时会有一小段时间的黑屏 
视频准备完成后,调用play进行播放视频,承载视频播放的View会是黑屏状态,我们只需要在播放前,给对应的Surface绘制一张图即可。 
6. 多个SurfaceView用来播放视频,滑动切换时会有上个视频的残影 
当视频切换出界面,设置surfaceView的visiable状态为Gone,界面切回来时再设置为visiable即可

最后

以上就是缥缈母鸡为你收集整理的MediaPlayer使用常见问题Valid and invalid states常见问题讨论的全部内容,希望文章能够帮你解决MediaPlayer使用常见问题Valid and invalid states常见问题讨论所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(58)

评论列表共有 0 条评论

立即
投稿
返回
顶部