我在我的网站上使用HTML5视频,其中某些其他代码基本上使可用性更加个性化。
视频用于在视野中播放,在不在视野时暂停。此外,当鼠标悬停在视频上时,它还有一个播放和暂停按钮。
在视频结束时,它会变成图像,因为默认情况下,html5视频只会变为空白。
问题是图像最终会出现,但播放/暂停会继续显示在悬停状态,并且只能作为播放暂停而只能播放音频。你看不到视频。
我原本希望它只显示图片。但如果视频结束,则希望将播放暂停变为重启按钮。
我尝试寻找适合我现有设置的东西,但我不确定如何实现它以及我将使用哪些代码。
以下是该网站的链接 http://minhasdistillery.com/blumersmoonshine/
<section id="feature">
<div id="trail">
<div id="videocontrol">
<a id="play-pause" class="play"><img src="images/pause.png"/></a>
</div>
<video id="video_background" preload="auto" volume="5"><!--or turn on loop="loop"-->
<source src="videos/video.webm" type="video/webm">
<source src="videos/video.mp4" type="video/mp4">
<source src="videos/video.ogv" type="video/ogg ogv">
</video>
<img id="image_background" src="images/blumer.jpg" width="100%" height="100%" />
</div><!--trail-->
</section><!--feature-->
调出播放/暂停按钮的Javascript
<script>
window.onload = function() {
var video = document.getElementById("video_background");
var playButton = document.getElementById("play-pause");
playButton.addEventListener("click", function() {
if (video.paused == true) {
video.play();
playButton.innerHTML = "<img src='images/pause.png'/>";
} else {
video.pause();
playButton.innerHTML = "<img src='images/play.png'/>";
}
});
}
</script>
代码设置视频在可见时播放,否则暂停
<script>
//play when video is visible
var videos = document.getElementsByTagName("video"), fraction = 0.8;
function checkScroll() {
for(var i = 0; i < videos.length; i++) {
var video = videos[i];
var x = 0,
y = 0,
w = video.offsetWidth,
h = video.offsetHeight,
r, //right
b, //bottom
visibleX, visibleY, visible,
parent;
parent = video;
while (parent && parent !== document.body) {
x += parent.offsetLeft;
y += parent.offsetTop;
parent = parent.offsetParent;
}
r = x + w;
b = y + h;
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);
if (visible > fraction) {
video.play();
} else {
video.pause();
}
}
}
window.addEventListener('scroll', checkScroll, false);
window.addEventListener('resize', checkScroll, false);
//check at least once so you don't have to wait for scrolling for the video to start
window.addEventListener('load', checkScroll, false);
checkScroll();
</script>
这张照片最后添加了照片。
<script>
var video = document.getElementById('video_background');
var wrapper = document.getElementById('wrapper');
var image = document.getElementById('image_background');
video.addEventListener('ended', function() {
video.style.display = 'none';
image.style.display = 'inline';
}, false);
</script>
同一问题的JSBin在这里 JSBin For Issue
正如您将在视频结尾处看到的那样,它将继续显示暂停和播放,并且只会播放音频。 如何让它读取视频已结束并将按钮切换为“重播”
答案 0 :(得分:1)
最初视频display
样式为block
,图片display
样式为none
。
视频ended
事件处理程序将视频display
设置为none
,将display
设置为inline
。
您可以在按钮display
事件处理程序中检查视频click
样式并切换它:
playButton.addEventListener(
'click',
function(event) {
if (video.style.display === 'none') {
image.style.display = 'none';
video.style.display = 'block';
}
...
},
false
);
作为替代方案,添加布尔标志,最初设置为false
,在视频ended
事件中将其设置为true
:
var needReplay = false;
video.addEventListener(
'ended',
function() {
...
needReplay = true;
},
false
);
playButton.addEventListener(
'click',
function(event) {
if (needReplay) {
image.style.display = 'none';
video.style.display = 'block';
needReplay = false;
}
...
},
false
);