使用此代码,我一滚动视频就会暂停。我想在视频消失时暂停视频。我该怎么做呢?
//This code loads the IFrame Player API code asynchronously.
var tag = document.createElement('script');
tag.src = "https://www.youtube.com/iframe_api";
var firstScriptTag = document.getElementsByTagName('script')[0];
firstScriptTag.parentNode.insertBefore(tag, firstScriptTag);
//This function creates an <iframe> (and YouTube player)
var player;
function onYouTubeIframeAPIReady() {
player = new YT.Player('video', {
height: '100%',
width: '100%',
videoId: 'V6Y-ahQFQDA',
playerVars: {
'start': '1',
'color': 'white',
'controls': '1',
'showinfo': '0'
},
events: {
'onReady': playOnScroll,
'onStateChange': playOnScroll
}
});
}
之前的部分是加载视频。我认为我的问题出在这个 if else 语句中。一旦我开始滚动日志就开始命令暂停,我无法让它工作。
function playOnScroll() {
var video = document.getElementById('video');
var x = video.offsetLeft,
y = video.offsetTop,
w = video.offsetWidth,
h = video.offsetHeight,
r = x + w, //right
b = y + h, //bottom
visibleX, visibleY, visible;
visibleX = Math.max(0, Math.min(w, window.pageXOffset + window.innerWidth - x, r - window.pageXOffset));
visibleY = Math.max(0, Math.min(h, window.pageYOffset + window.innerHeight - y, b - window.pageYOffset));
visible = visibleX * visibleY / (w * h);
var percent = 0.6;
var inView = visible > percent;
if (inView) {
console.log('play');
player.playVideo();
} else {
console.log('paused');
player.pauseVideo();
}
}
window.addEventListener('scroll', playOnScroll, false);
window.addEventListener('resize', playOnScroll, false);