加载中…
正文 字体大小:

Android WebView 播放视频总结~

(2013-11-10 17:24:50)
标签:

android

webview

hardwareaccelerated

it

分类: Android
今天发现 WebView里播放优酷的视频点击播放按钮后没反应,于是看官方文档和搜索解决,下面是我在别人基础上做的补充:

android webView 无法播放视频,无法暂停,继续播放视频问题,无法根据浏览器居中显示内容问题

此次遇到一个问题就是webView无法播放视频,查了下谷歌发现可以设置

setting.setPluginsEnabled(true); (从API 11 支持,可以不加)
这个从而播放视频,但是最新官方SDK说这个方法要放弃了,推荐使用

setting.setPluginState(PluginState.ON);(从API 11 支持,可以不加)
目前看来这两种方法都可以,但是webview的页面都finish了居然还能听到视频播放的声音,于是有查了下发现webview的

onResume方法可以继续播放,

onPause可以暂停播放,
但是这两个方法都是在Added in API level 11添加的,所以需要用反射来完成。
停止播放:在页面的onPause方法中使用:

webView.getClass().getMethod("onPause").invoke(webView,(Object[])null);(低版本测试正常)
继续播放:在页面的onResume方法中使用:

 

webView.getClass().getMethod("onResume").invoke(webView,(Object[])null);低版本测试正常

这样就可以控制视频的暂停和继续播放了。


另外说一点:

webView.resumeTimers()(不靠谱)

webView.pauseTimers();不靠谱

这两个方法有延迟,而且第二次再加载webview以后会出现上次播放的视频还会继续在播放,但是只能听到声音,所以个人感觉不靠谱,系统的浏览器估计是用了这个方法,按返回件关闭浏览器后都还能听到声音。


无法根据浏览器居中显示内容这个问题只要设置下面两个熟悉即可:

 

setting.setLoadWithOverviewMode(true);

setting.setUseWideViewPort(true);


继续研究:

同样的代码,经过在Android4.0+的设备上测试后发现,还是不能播放视频,于是继续添加了如下解决方法:

1.在webView的Activity配置里面加上:

android:hardwareAccelerated="true" 

(官方文档解释说:

Hardware acceleration is enabled by default if your Target API level is >=14 

http://developer.android.com/guide/topics/graphics/hardware-accel.html 

所以只需要修改下Manifest文件,不需要设置这个属性也可以)


2.必须添加这句代码,没整明白为什么,但是加了这个就能播放

webView.setWebChromeClient(new WebChromeClient()); (一定要加

这两步就可以播放了,有人说在application的配置里面也要加上:android:hardwareAccelerated="true",开始的时候我也加了,但是后来发现去掉这个也一样可以播放flash

但是现在的麻烦是视频不能全屏播放,只要点击了全屏按钮后,再次点击播放和暂停按钮以后,视频不会有任何反应,无法继续播放了。

网上查了下相关解决方法:
http://www.techfreestyle.com/fixed-android-4-0-full-screen-flash-problem-in-webview  这种方法测试过了 不能解决问题。

https://github.com/android/platform_packages_apps_browser/blob/master/src/com/android/browser/BaseUi.java 这个貌似源码,由于代码较多,所以还没研究。


0

阅读 评论 收藏 转载 喜欢 打印举报
  • 评论加载中,请稍候...
发评论

    发评论

    以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

      

    新浪BLOG意见反馈留言板 电话:4006900000 提示音后按1键(按当地市话标准计费) 欢迎批评指正

    新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 会员注册 | 产品答疑

    新浪公司 版权所有