• 【转】Android WebView 播放视频总结


     

    今天发现 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 这个貌似源码,由于代码较多,所以还没研究。

  • 相关阅读:
    raw_input() 与 input()对比
    你很熟悉CSS,却没掌握这些CSS技巧
    CSS样式设置
    javascript基本语法和变量(转)
    手机/移动前端开发需要注意的20个要点
    移动端”宴席知多少
    git第一次提交代码到远程仓库
    java对过反射调用方法
    站点收集
    别人抢红包,我们研究一下红包算法
  • 原文地址:https://www.cnblogs.com/wangzehuaw/p/4346480.html
Copyright © 2020-2023  润新知