javascript – 如何通过YouTube播放器IFrame API区分“搜索”和“暂停”
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何通过YouTube播放器IFrame API区分“搜索”和“暂停”,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1457字,纯文字阅读大概需要3分钟。
内容图文
![javascript – 如何通过YouTube播放器IFrame API区分“搜索”和“暂停”](/upload/InfoBanner/zyjiaocheng/756/de4292a17cfd4986a9d995e369dc0a29.jpg)
我有一个youtube视频,我已经嵌入了youtube的iFrame API.我想要:
>当用户暂停视频时显示半透明叠加层(WORKS)
>当用户播放视频时隐藏该叠加层(WORKS)
>当用户通过youtube控件“搜索”时,不显示叠加层(可能?)
无法控制搜索行为.可能吗?
要重现,请将搜索保持在相同位置几秒钟,然后观看叠加显示.示例jsfiddle在这里:
http://jsfiddle.net/dNU84/3/
var ytvideo;
window.onYouTubePlayerAPIReady = function () {
ytvideo = new YT.Player('ytvideo', {
width: '400',
height: '300',
videoId: 'BOksW_NabEk',
playerVars: {
'autoplay': 1,
'controls': 1
},
events: {
"onStateChange": onPlayerStateChange
}
});
}
function showOverlay() {
if ($('.video .video-overlay').length) $('.video .video-overlay').fadeIn(1200);
}
function hideOverlay() {
if ($('.video .video-overlay').length) $('.video .video-overlay').hide();
}
var overlay;
function onPlayerStateChange(event) {
console.log(event.data);
clearTimeout(overlay);
// youtube fires 2xPAUSED, 1xPLAYING on seek
if (event.data == YT.PlayerState.PAUSED) {
overlay = setTimeout(showOverlay, 1000);
}
if (event.data == YT.PlayerState.PLAYING) {
overlay = hideOverlay();
}
}
解决方法:
我知道这个问题已经过时了,但我只是在寻找解决方案,因为我在暂停时会显示一个叠加层,但是每次用户搜索时都会显示叠加层,因为两个事件值都是2.
我遇到的最简单的解决方案是设置一秒超时:
setTimeout(function() {
if ( event.target.getPlayerState() == 2 ) {
// execute your code here for paused state
}
}, 1000)
这只会在暂停状态下执行代码,而不是在搜索时执行,因为在1秒超时之后,如果用户正在寻求,则PlayerState将再次为1.
内容总结
以上是互联网集市为您收集整理的javascript – 如何通过YouTube播放器IFrame API区分“搜索”和“暂停”全部内容,希望文章能够帮你解决javascript – 如何通过YouTube播放器IFrame API区分“搜索”和“暂停”所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。