【转】Android HTML5 Video视频标签自动播放与自动全屏问题解决
为了解决 HTML5Video视频标签自动播放与全屏问题,在网上找了很多相关资料,网上也很多关于此问题解决方法,但几乎都不能解决问题,特别对各大视频网站传回来的html5网页视频自动播放与全屏问题,我是这样解决的:
- webview.setWebChromeClient(new WebChromeClient() {
- public void onShowCustomView(View view, CustomViewCallback callback) {
- Log.e("Media", "onShowCustomView ............ ");
- if (myCallback != null) {
- myCallback.onCustomViewHidden();
- myCallback = null ;
- Log.e("Media", "myCallback.onCustomViewHidden()...");
- return;
- }
- long id = Thread.currentThread().getId();
- ViewGroup parent = (ViewGroup) webview.getParent();
- String s = parent.getClass().getName();
- Log.v("WidgetChromeClient", "rong debug Ex: " + s);
- parent.removeView( webview);
- parent.addView(view);
- myView = view;
- myCallback = callback;
- }
- private View myView = null;
- private CustomViewCallback myCallback = null;
- public void onHideCustomView() {
- long id = Thread.currentThread().getId();
- Log.v("Media", "onrong debug in hideCustom Ex: " + id);
- if (myView != null) {
- if (myCallback != null) {
- myCallback.onCustomViewHidden();
- myCallback = null ;
- }
- ViewGroup parent = (ViewGroup) myView.getParent();
- parent.removeView( myView);
- parent.addView(webview);
- myView = null;
- }
- }
- });
这段代码网上很多地方能找到的,但这是实现全屏播放的前提,一旦触发全屏事件,系统就会调用onShowCustomView方法
实现自动播放功能,就是在网络加载完成后,再延时一些时间如1s后,执行这JAVA脚本
- String js="javascript: var v=document.getElementsByTagName('video')[0]; "
- +"v.play(); ";
- webview.loadUrl(js);
这样就可以自动开始播放了
要实现让它自动全屏播放,可以执行这JAVA脚本:
- String js="javascript: var v=document.getElementsByTagName('video')[0]; "+"v.webkitEnterFullscreen(); ";
- webview.loadUrl(js);
注意实现全屏播放要在视频开始播放后,才能调用,否则可能会现异常
如果你想知道视频什么时候开始播放,就是得到视频开始播放事件,方法如下:
先在代码上定义这样接口
- private final class DemoJavaScriptInterface
- {
- DemoJavaScriptInterface(){}
- public void clickonAndroid(){
- Toast.makeText(getApplicationContext(), "视频开始播放...",Toast.LENGTH_SHORT).show();
- }
- public void endonAndroid(){
- Toast.makeText(getApplicationContext(), "视频结束",Toast.LENGTH_SHORT).show();
- }
- }
- webview.addJavascriptInterface(new DemoJavaScriptInterface(), "demo");
然后在在视频开始播放之前,执行这JAVA脚本
- String js="javascript: var v=document.getElementsByTagName('video')[0]; "
- +"v.addEventListener('playing', function() { window.demo.clickonAndroid(); }, true); ";
- webview.loadUrl(js);
当然了你也可以得到视频播放结束事件执行这JAVA脚本
- String js="javascript: var v=document.getElementsByTagName('video')[0]; "
- +"v.addEventListener('ended', function() { window.demo.endonAndroid(); }, true); ";
- webview.loadUrl(js);
一般在android平台上,网络视频网站可能不会给你传回Html5 Video网页,这时候就可以设置UserAgent,如可能设置成IPhone或IPad环境,让它返回tml5 Video网页
- webview.getSettings().setUserAgentString("Mozilla/5.0 (iPad; CPU OS 5_1 " +
- "like Mac OS X) AppleWebKit/534.46 (KHTML, like Gecko ) Version/5.1 " +
- "Mobile/9B176 Safari/7534.48.3");
以上方法就是我在Android 网页视频一些心得,也许能给在你这方面开发提供帮助
【转】Android HTML5 Video视频标签自动播放与自动全屏问题解决的更多相关文章
- HTML5 video 视频标签 常用属性
最近在做手机端的 h5 页面的视频直播功能,用到了 Video 标签.其常用的属性有以下几个: src.poster.preload.autoplay.loop.controls.width.heig ...
- HTML5 video 视频标签全属性详解
现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera.Mozilla.Chrome),支持H.264的(Safari.IE ...
- iphone H5视频行内播放(禁止全屏播放)
一般用户都知道,ios在网页点击视频播放时,视频会弹出全屏播放框. video标签的playsinline.webkit-playsinline标记根本就不会起作用. 还有传闻说对于没有声音的视频不会 ...
- 让所有浏览器支持HTML5 video视频标签
HTML5究竟需要多少种视频编码格式 当前,video 元素支持三种视频格式:Ogg = 带有 Theora 视频编码和 Vorbis 音频编码的 Ogg 文件MPEG4 = 带有 H.264 视频编 ...
- video视频标签一些设置,包括封面、播放结束后的封面、视频占满屏幕的方式、视频播放暂停、展示控制栏、触发全屏播放事件
video视频标签一些设置,包括封面.播放结束后的封面.视频占满屏幕的方式.视频链接.视频播放暂停.展示控制栏.触发全屏播放事件 <video id="video" auto ...
- HTML video 视频标签全属性详解
HTML 5 video 视频标签全属性详解 现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera.Mozilla.C ...
- HTML5 Video(视频)
HTML5 Video(视频) 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 HTML5 视频: 检测 Web站点上的视频 直到现在,仍然不存在一项旨在网页上显 ...
- HTML5: HTML5 Video(视频)
ylbtech-HTML5: HTML5 Video(视频) 1.返回顶部 1. HTML5 Video(视频) 很多站点都会使用到视频. HTML5 提供了展示视频的标准. 检测您的浏览器是否支持 ...
- HTML5中音频视频标签使用
HTML5中音频视频标签使用的最好方式 Html5中提供了<audio> <vedio>元素实现音频视频的引入播放 然而更好的方式
随机推荐
- MFC窗体大小变化
对话框的大小变化后,假若对话框上的控件大小不变化,看起来会比较难看.下面就介绍怎么让对话框上的控件随着对话框的大小的变化自动调整. 首先明确的是Windows有一个WM_SIZE消息响应函数,这个函数 ...
- os下,vs code 自动编译ts
nodejs安装ts npm install -g typescript 进入工程目录,用命令初始化ts(生成tsconfig.json) tsc --init 如果要指定生成目录,打开tsconfi ...
- PHP图像函数
(1)常见的验证码哪些? 图像类型.语音类型.视频类型.短信类型等 (2)使用验证码的好处在哪里? ①防止恶意的破解密码如一些黑客为了获取到用户信息,通过不同的手段向服务器发送数据,验证猜测用户信 ...
- Pycharm中通过扩展工具添加QTDesigner
1.在电脑中找到Designer.exe的安装目录: 2.在pycharm中打开file->Settings->Tools->External Tools进行配置: 配置如下图所示: ...
- nginx配置X-Forwarded-For 防止伪造ip
网上常见nginx配置ip请求头 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 风险: 用于可以通过自己设置请求头来伪造ip ...
- acm相关(纯转载)
我觉得很好的文章,之所以放随笔是为了让大家看到这些优秀的博文 acm如何起步 acm重点题型 动态规划题目总结 背包九讲阅读网站
- acm学习指引
acm学习心得及书籍推荐 一般要做到50行以内的程序不用调试.100行以内的二分钟内调试成功.acm主要是考算法的,主要时间是花在思考算法上,不是花在写程序与debug上. 下面给个计划练练: 第 ...
- C++/C union使用记一下锅
//首先,学习编程一定要记得加几个群或者加几个讨论组,因为这样你才能不断地进步还有吵架/滑稽 记一下 关于使用union结构体时遇到的一些坑 To zero-initialize an object ...
- Django DTL模板语法中的url反转
"""template_url_demo URL Configuration The `urlpatterns` list routes URLs to views. F ...
- 正确的在循环list的时候删除list里面的元素
s = [1,2,3,4,5] for i in s: s.remove(i) print(s) 输出结果:[2, 4] 1.当第一次删除后,后面的元素会前移,此时s=[2,3,4,5], 2.然 ...