html5视频:播放/暂停自定义按钮问题

时间:2014-07-09 20:42:45

标签: javascript html5 video html5-video custom-controls

我在我的网站上使用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

正如您将在视频结尾处看到的那样,它将继续显示暂停和播放,并且只会播放音频。 如何让它读取视频已结束并将按钮切换为“重播”

1 个答案:

答案 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
);

Demo