Альтернатива для проверки простоя браузера

У меня есть простой веб-киоск, который отображает приглашение пользователя через 30 секунд, когда мышь не двигается с помощью jQuery.

var i = null;
  $("#body-wrap").mousemove(function() {
    clearTimeout(i);
    $("#overlay").fadeOut();
    i = setTimeout(function() {
      $("#overlay").fadeIn();
    }, 30000);
  })

Киоск - стенд для выбора видео. Видео воспроизводится в полноэкранном режиме, и я столкнулся с проблемой, когда действие отображается под видеокадром, потому что мышь не двигалась.

Есть ли способ проверить активность браузера с помощью JavaScript, кроме событий мыши или ключа?

2 ответа

Решение

В зависимости от того, как вы воспроизводите видео, переключите глобальный флаг, videoPlaying, на видео воспроизведения / паузы. Затем;

$("#body-wrap").mousemove(function() {
    clearTimeout(i);
    $("#overlay").fadeOut();
    i = setTimeout(function() {
      if(!videoPlaying)
        $("#overlay").fadeIn();
    }, 30000);
  })

Видео воспроизводится в полноэкранном режиме, и я столкнулся с проблемой, когда действие отображается под видеокадром, потому что мышь не двигалась.

Если проблема в том, что сообщение для пользователя отображается ниже <video> элемент, когда пользователь запросил полноэкранное отображение, вы можете использовать <track> элемент с src установлен в .vtt файл или .addTextTrack() метод HTMLMediaElement, VTTCue(), .addCue() добавить cue сообщение для отображения на <video> элемент в определенное время.

использование loadedmetadata а также ended событие HTMLMediaElement установить, сбросить TextTrackCue, Также установить, сброс cue до 30 секунд от текущей активности пользователя на mousemove обработчик события.

Вы можете просмотреть связанный PLNKR на новый window кликнув "Launch the preview in a separate window" значок, затем нажмите <button> элемент с текстом "toggle fullscreen",

<!DOCTYPE html>
<html>
<head>
 <style>
 ::cue {
   background: transparent;
 }

 ::cue(.prompt) {
   color: #d81159;
   background: transparent;
   text-shadow: 2px 2px 2px #ffbc42;
   font-family: Menlo, Sans, Monospace;
   font-size: 36px;
   display: block;
   width: 100px;
 }

 ::cue(b) {
   display: block;
   width: 100px;
 }
 </style>
</head>
<body>
<button>
  toggle fullscreen
</button>
<br>
<video 
  width="320px"
  height="280px"
  autoplay="autoplay" 
  controls="controls"
  src="http://nickdesaulniers.github.io/netfix/demo/frag_bunny.mp4"
  poster="">     
</video>
<script>
  var video = document.querySelector("video");
  var button = document.querySelector("button");
  video.requestFullscreen = video.requestFullscreen 
                            || video.mozRequestFullscreen 
                            || video.webkitRequestFullscreen;
  video.exitFullscreen = video.exitFullscreen 
                         || video.mozExitFullscreen 
                         || video.webkitExitFullscreen;
  var track = video.addTextTrack("captions", "prompt", "en");
  track.mode = "showing";
  var overlay = "<c.prompt><b>No browser activity<b></c>";
  var isFullscreen = false;
  var currentCue;
  var duration;

  video.onloadedmetadata = function(e) {
    duration = this.duration;
    currentCue = createCue(30, Math.round(duration));
    track.addCue(currentCue);
  }

  video.onended = video.onpause = function() {
    removeCues(track);
    console.log(track.cues);
    currentCue = createCue(30
                   , Math.round(duration || video.duration));
    track.addCue(currentCue);
  }

  button.onclick = function() {
    if (isFullscreen) {
      video.exitFullscreen;
      video.setAttribute("width", "320px");
      video.setAttribute("height", "280px");
      isFullscreen = false;
    } else {
      video.removeAttribute("width");
      video.removeAttribute("height");
      video.requestFullscreen();
      isFullscreen = true;
    }
  }
  
  window.onmousemove = function() {
    if (track.cues.length && currentCue && duration) {
      removeCues(track);
      currentCue = createCue(
        Math.round(video.currentTime) + 30
        , Math.round(duration || video.duration)
      );
      track.addCue(currentCue);
    }
  }

  function createCue(begin, end) {
    var cue = new VTTCue(begin, end, overlay);
    cue.line = 5;
    cue.size = 100;
    return cue
  }

  function removeCues(track) {
    for (var i = 0; i < track.cues.length; i++) {
      track.removeCue(track.cues[i]);
    }
  }
</script>
</body>
</html>

Другие вопросы по тегам