javascript - 检查浏览器空闲的替代方法

标签 javascript jquery

我有一个简单的网络信息亭,它会在 jQuery 鼠标停止移动 30 秒后显示用户操作提示。

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

信息亭是一个视频选择台。视频全屏播放,但我遇到了一个问题,即由于鼠标没有移动, Action 显示在视频帧下方。

除了鼠标或按键事件之外,还有其他方法可以使用 JavaScript 检查浏览器事件吗?

最佳答案

The video is played full screen and I'm running into an issue where the action is displayed beneath the video frame because the mouse hasn't moved.

如果问题是在 <video> 下方呈现给用户的消息元素当用户要求全屏显示时,可以使用<track>带有 src 的元素设置为 .vtt文件,或 .addTextTrack() HTMLMediaElement的方法| , VTTCue() , .addCue()添加 cue要显示在 <video> 的消息特定时间的元素。

使用 loadedmetadataended HTMLMediaElement的事件设置、重置 TextTrackCue .同时设置、重置cue从当前用户在 mousemove 的事件开始减少到 30 秒事件处理程序。

您可以查看链接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>

关于javascript - 检查浏览器空闲的替代方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39553729/

相关文章:

javascript - Vuejs 中渲染函数的两种方式绑定(bind)

javascript - 如何获取AngularJS Controller 中输入字段的值

javascript - JavaScript 中的单词词典及其翻译

javascript - 在局部变量中保存重复访问的对象属性是否有缺点?

javascript - 如何仅在新图像实际可用时才刷新图像源?

javascript - jQuery 是 (":first") 无效

php - 注册后如何显示弹框?

javascript - 避免多次点击一个 div

javascript - AJAX 页面重定向正确。但由于重定向传递的数据要刷新

javascript - 更新到 Chrome v65 并开始收到此错误 : Expected onClick listener to be a function, 而不是收到类型字符串