前端写的h5页面有声音自动播放效果,但是嵌到andriod的webview之后发现并不能正常播放,ios一开始也不是能播放的,需要用户与界面互动之后才能播放,但是ios可以通过设置setMediaPlaybackRequiresUserAction,解决这个问题,但是andriod没有类似的方法。
查了下解决方法:
view.loadUrl("javascript:(function() { " + "var videos = document.getElementsByTagName('video');" + " for(var i=0;i<videos.length;i++){videos[i].play();}})()");
在webview的onPageFinished回调调用,把video换成audio试了试,然而并不起作用。
解决方法
查了下说webkit内核的浏览器不支持声音自动播放,那就换个浏览器吧
看了下微信内核是x5的,而且有sdk
地址:http://x5.tencent.com/
导入sdk后的步骤:
1 在Application类中添加
TbsDownloader.needDownload(getApplicationContext(), false);
2 在调用webview的地方添加
this.handler=newHandler(Looper.getMainLooper()){
@Override
public voidhandleMessage(Message msg) {
//TODO Auto-generated method stub
switch(msg.what){
caseMSG_WEBVIEW_CONSTRUCTOR:
//之后做初始化操作,setContentView 必须要放在这里才能在第一次的时候就可以加载到X5内核
setContentView(R.layout.*****);
((TextView) findViewById(R.id.title_name)).setText("***");
initView();
break;
}
super.handleMessage(msg);
}
};
this.preinitX5WebCore();
/**
* X5内核在使用preinit接口之后,对于首次安装首次加载没有效果
*实际上,X5webview的preinit接口只是降低了webview的冷启动时间;
*因此,现阶段要想做到首次安装首次加载X5内核,必须要让X5内核提前获取到内核的加载条件
*/
private voidpreinitX5WebCore(){
if(!QbSdk.isTbsCoreInited()){//preinit只需要调用一次,如果已经完成了初始化,那么就直接构造view
//这里在系统内没有集成X5的时候回调用
QbSdk.preInit(ReadCloudImgAct.this,myCallback,true);//设置X5初始化完成的回调接口 第三个参数为true:如果首次加载失败则继续尝试加载;
}else{
//直接初始化webview
handler.sendEmptyMessageDelayed(MSG_WEBVIEW_CONSTRUCTOR,500);//延时500ms的构建webview(为冷启动争取时间)
}
}
privateQbSdk.PreInitCallbackmyCallback=newQbSdk.PreInitCallback() {
@Override
public voidonViewInitFinished() {//当X5webview初始化结束后的回调
//TODO Auto-generated method stub
ReadCloudImgAct.this.handler.sendEmptyMessageDelayed(MSG_WEBVIEW_CONSTRUCTOR,500);
}
@Override
public voidonCoreInitFinished() {
//TODO Auto-generated method stub
}
};
接下来就可以正常使用webView了
若文章对您有帮助望不吝点赞,若有不足的地方欢迎交流
联系方式:
qq:1251600274
wechat:gudao___