为了解决 HTML5Video视频标签自动播放与全屏问题,在网上找了很多相关资料,网上也很多关于此问题解决方法,但几乎都不能解决问题,特别对各大视频网站传回来的html5网页视频自动播放与全屏问题,我是这样解决的:

  1. webview.setWebChromeClient(new WebChromeClient() {
  2. public void onShowCustomView(View view, CustomViewCallback callback) {
  3. Log.e("Media", "onShowCustomView ............ ");
  4. if (myCallback != null) {
  5. myCallback.onCustomViewHidden();
  6. myCallback = null ;
  7. Log.e("Media", "myCallback.onCustomViewHidden()...");
  8. return;
  9. }
  10. long id = Thread.currentThread().getId();
  11. ViewGroup parent = (ViewGroup) webview.getParent();
  12. String s = parent.getClass().getName();
  13. Log.v("WidgetChromeClient", "rong debug Ex: " + s);
  14. parent.removeView( webview);
  15. parent.addView(view);
  16. myView = view;
  17. myCallback = callback;
  18. }
  19. private View myView = null;
  20. private CustomViewCallback myCallback = null;
  21. public void onHideCustomView() {
  22. long id = Thread.currentThread().getId();
  23. Log.v("Media", "onrong debug in hideCustom Ex: " + id);
  24. if (myView != null) {
  25. if (myCallback != null) {
  26. myCallback.onCustomViewHidden();
  27. myCallback = null ;
  28. }
  29. ViewGroup parent = (ViewGroup) myView.getParent();
  30. parent.removeView( myView);
  31. parent.addView(webview);
  32. myView = null;
  33. }
  34. }
  35. });

这段代码网上很多地方能找到的,但这是实现全屏播放的前提,一旦触发全屏事件,系统就会调用onShowCustomView方法
实现自动播放功能,就是在网络加载完成后,再延时一些时间如1s后,执行这JAVA脚本

  1. String js="javascript: var v=document.getElementsByTagName('video')[0]; "
  2. +"v.play(); ";
  3. webview.loadUrl(js);

这样就可以自动开始播放了
要实现让它自动全屏播放,可以执行这JAVA脚本:

  1. String js="javascript: var v=document.getElementsByTagName('video')[0]; "+"v.webkitEnterFullscreen(); ";
  2. webview.loadUrl(js);

注意实现全屏播放要在视频开始播放后,才能调用,否则可能会现异常

如果你想知道视频什么时候开始播放,就是得到视频开始播放事件,方法如下:
先在代码上定义这样接口

  1. private final class DemoJavaScriptInterface
  2. {
  3. DemoJavaScriptInterface(){}
  4. public void clickonAndroid(){
  5. Toast.makeText(getApplicationContext(), "视频开始播放...",Toast.LENGTH_SHORT).show();
  6. }
  7. public void endonAndroid(){
  8. Toast.makeText(getApplicationContext(), "视频结束",Toast.LENGTH_SHORT).show();
  9. }
  10. }
  1. webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");

然后在在视频开始播放之前,执行这JAVA脚本

  1. String js="javascript: var v=document.getElementsByTagName('video')[0]; "
  2. +"v.addEventListener('playing', function() { window.demo.clickonAndroid(); }, true); ";
  3. webview.loadUrl(js);

当然了你也可以得到视频播放结束事件执行这JAVA脚本

  1. String js="javascript: var v=document.getElementsByTagName('video')[0]; "
  2. +"v.addEventListener('ended', function() { window.demo.endonAndroid(); }, true); ";
  3. webview.loadUrl(js);

一般在android平台上,网络视频网站可能不会给你传回Html5 Video网页,这时候就可以设置UserAgent,如可能设置成IPhone或IPad环境,让它返回tml5 Video网页

  1. webview.getSettings().setUserAgentString("Mozilla/5.0 (iPad; CPU OS 5_1 " +
  2. "like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko ) Version/5.1 " +
  3. "Mobile/9B176 Safari/7534.48.3");

以上方法就是我在Android 网页视频一些心得,也许能给在你这方面开发提供帮助

【转】Android HTML5 Video视频标签自动播放与自动全屏问题解决的更多相关文章

  1. HTML5 video 视频标签 常用属性

    最近在做手机端的 h5 页面的视频直播功能,用到了 Video 标签.其常用的属性有以下几个: src.poster.preload.autoplay.loop.controls.width.heig ...

  2. HTML5 video 视频标签全属性详解

    现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera.Mozilla.Chrome),支持H.264的(Safari.IE ...

  3. iphone H5视频行内播放(禁止全屏播放)

    一般用户都知道,ios在网页点击视频播放时,视频会弹出全屏播放框. video标签的playsinline.webkit-playsinline标记根本就不会起作用. 还有传闻说对于没有声音的视频不会 ...

  4. 让所有浏览器支持HTML5 video视频标签

    HTML5究竟需要多少种视频编码格式 当前,video 元素支持三种视频格式:Ogg = 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件MPEG4 = 带有 H.264 视频编 ...

  5. video视频标签一些设置,包括封面、播放结束后的封面、视频占满屏幕的方式、视频播放暂停、展示控制栏、触发全屏播放事件

    video视频标签一些设置,包括封面.播放结束后的封面.视频占满屏幕的方式.视频链接.视频播放暂停.展示控制栏.触发全屏播放事件 <video id="video" auto ...

  6. HTML video 视频标签全属性详解

    HTML 5 video 视频标签全属性详解   现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera.Mozilla.C ...

  7. HTML5 Video(视频)

    HTML5 Video(视频) 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 HTML5 视频: 检测 Web站点上的视频 直到现在,仍然不存在一项旨在网页上显 ...

  8. HTML5: HTML5 Video(视频)

    ylbtech-HTML5: HTML5 Video(视频) 1.返回顶部 1. HTML5 Video(视频) 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 ...

  9. HTML5中音频视频标签使用

    HTML5中音频视频标签使用的最好方式 Html5中提供了<audio> <vedio>元素实现音频视频的引入播放 然而更好的方式

随机推荐

  1. 00Enterprise Resource Planning

    Enterprise Resource Planning         企业资源计划即 ERP (Enterprise Resource Planning),由美国 Gartner Group 公司 ...

  2. WebBrowser之获取跳转页面的Document接口源码

    问题由来是这样的,今天帮一个网友解决问题,说从VC驿站下载了一个源码,程序的功能主要是在对话框上面放置了一个WebBrowser控件,程序启动的时候默认调用这句代码: m_web.Navigate(_ ...

  3. 通过docker-composer启动容器nginx,并完成spring.boot的web站点端口转发

    前面已经讲过2篇基于docker的mysql.redis容器编排并启动.这次将练习下nginx的docker方式的部署,以及通过nginx去代理宿主主机上的Web服务应该怎么配 PS:(这里由于ngi ...

  4. Laravel学习:请求到响应的生命周期

    Laravel请求到响应的整个执行过程,主要可以归纳为四个阶段,即程序启动准备阶段.请求实例化阶段.请求处理阶段.响应发送和程序终止阶段. 程序启动准备阶段 服务容器实例化 服务容器的实例化和基本注册 ...

  5. Delphi语法

    类与对象 从用户角度考虑,用户并不需要了解面向对象编程的知识,就可编写Delphi应用程序.当用户在建立新窗体.添加新组件以及处理事件时,大部分相关代码会由Delphi自动产生.但是,知道语言及其细节 ...

  6. Modify MySQL dump file the fatest way

    使用mysql命令导入mysqldump生成的sql文件时,为了提高导入速度,往往需要修改dump文件,但是面对一个几十GB的文件,这事儿就太崩溃了,最快速的方法是这么做: ( echo " ...

  7. [luoguP1879] [USACO06NOV]玉米田Corn Fields(DP)

    传送门 说要统计方案,感觉就是个 Σ 而矩阵中只有 01 ,可以用二进制表示 这样,预处理出每一个每一行所有可能的状态 s 然后初始化第一行所有状态的方案数为 1 f[i][j] = Σf[i - 1 ...

  8. (13)Corner Detection角点检测

    import cv2 import numpy as np img=cv2.imread('opencv-corner-detection-sample.jpg') gray = cv2.cvtCol ...

  9. 使用java操作hbase(单节点)

    1.在运行java代码之前,一定要先启动Hbase,很重要!!    cd /home/cx/itcast/hbase-1.2.6/bin   ./start-hbase.sh 2.新建一个java项 ...

  10. Calculate S(n)

    Problem Description Calculate S(n). S(n)=13+23 +33 +......+n3 .   Input Each line will contain one i ...