我开发了一个用户可以在网页上设置视频的应用程序: - 他们可以指定Youtube网址 要么 - 他们可以上传视频
根据用户选择的选项,我会像这样渲染视频页面: 如果视频来自youtube:
<iframe type="text/html" width="640" height="385" src="http://www.youtube.com/embed/YOUTUBEID?autoplay=1&loop=1&autohide=1&fs=0" frameborder="0"></iframe>
如果正在上传视频:
<video id="video" style="cursor: pointer;" width="640" height="480" autoplay controls loop>
<source src="../video/Tareas_Diarias_Resumen.mp4" type="video/mp4" />
</video>
行。所有这一切在谷歌浏览器上都很完美,但事实是该视频将在16款三星GT-P5100 Android 4.03平板电脑上观看。
我们创建了一个嵌入webView的Android应用程序:
WebView engine = (WebView) findViewById(R.id.web_engine);
engine.setWebChromeClient(new WebChromeClient());
engine.getSettings().setPluginsEnabled(true);
engine.getSettings().setPluginState(PluginState.ON);
engine.getSettings().setJavaScriptEnabled(true);
engine.getSettings().setAllowFileAccess(true);
engine.loadUrl(miUrl);
这里我有两个问题: 1- Youtube视频。它工作正常,我可以看到视频,但没有自动播放,我们希望它与自动播放一起使用。有解决方案吗 2-上传的视频不起作用,我可以看到播放器,但没有视频。
视频转换为手刹,选择iphone&amp; amp; ipod-touch预置和&#34; Web优化&#34;选项。
任何帮助或线索? 提前致谢
答案 0 :(得分:26)
自Android SDK 17起禁用自动播放,但您可以将setMediaPlaybackRequiresUserGesture设置为false以重新启用自动播放。 不要忘记检查SDK版本,因为在早期版本中没有这样的功能。
int SDK_INT = android.os.Build.VERSION.SDK_INT;
if (SDK_INT > 16) {
engine.getSettings().setMediaPlaybackRequiresUserGesture(false);
}
答案 1 :(得分:8)
[升级为按要求回答]
大多数移动平台(Android,iOS)上的自动播放被屏蔽以避免糟糕的用户体验 - 视频应仅在用户操作后播放。您通常可以通过触发另一个事件(例如,加载的事件)上的play()来解决它。
答案 2 :(得分:4)
对于Android 4.0.x,请尝试触发事件:loadstart
var vid=document.getElementById('video');
vid.addEventListener("loadstart", showVideo, false);
function showVideo(e) {
vid.play();
}
答案 3 :(得分:0)
无法实现,大多数移动平台(Android,iOS)上的自动播放被阻止,以避免糟糕的用户体验。看这个: http://www.longtailvideo.com/html5/autoloop/