13

我喜欢videoJS,但找不到让控制栏始终可见的方法(播放时不会淡出)。我搜索了相关信息并找到了一个关于它的主题,他们建议像这样覆盖函数隐藏:

/覆盖控件自动隐藏fn /

隐藏 = function(){ /* 什么都没有 */ };

但这可能已经过时了,因为它在这里不起作用。(版本 3.2.0)

有谁知道我怎么能做到这一点?

非常感谢 !

4

4 回答 4

38

只是这里多了一点死灵法...

虽然 Peter Kitts 的最后一个答案可以正常工作,但另一个选项是将 设置inactivityTimeout为 0,这将完全禁用不活动超时。

<link href="http://vjs.zencdn.net/4.12/video-js.css" rel="stylesheet">
<script src="http://vjs.zencdn.net/4.12/video.js"></script>

<video id="my_video_1" class="video-js vjs-default-skin" controls preload="auto" width="640" height="268" 
  data-setup='{ "inactivityTimeout": 0 }'>
  <source src="http://vjs.zencdn.net/v/oceans.mp4" type='video/mp4'>
  <source src="http://vjs.zencdn.net/v/oceans.webm" type='video/webm'>
</video>

于 2015-06-16T00:20:31.170 回答
4

我知道这个问题现在已经有几年了,但我也需要这样做,并且上面的答案使控件保持在视频的顶部。我在自己的 CSS 文件中使用了以下 CSS 来覆盖 videoJS 样式,以在视频开始播放后保持控件可见并将它们保持在视频下方。

.vjs-default-skin.vjs-has-started .vjs-control-bar {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  bottom: -3.4em !important;
  background-color: rgba(7, 20, 30, 1) !important;
}
于 2014-10-02T08:48:25.050 回答
3

谢谢 !我找到了另一个解决方案,因为我想避免破解原始文件,添加这是我的 CSS :

.vjs-fade-in,.vjs-fade-out {
visibility: visible !important;
opacity: 1 !important;
transition-duration: 0s!important;
}

谢谢 !

于 2012-11-15T11:09:10.497 回答
2

从video-js.css的and类中注释掉/删除visibility:hiddenandopacity:0规则。.vjs-fade-out.vjs-default-skin .vjs-controls

.vjs-fade-out {
    /*visibility: hidden!important;
    opacity: 0!important;*/
    -webkit-transition: visibility 0s linear 1.5s,opacity 1.5s linear;
    -moz-transition: visibility 0s linear 1.5s,opacity 1.5s linear;
    -ms-transition: visibility 0s linear 1.5s,opacity 1.5s linear;
    -o-transition: visibility 0s linear 1.5s,opacity 1.5s linear;
    transition: visibility 0s linear 1.5s,opacity 1.5s linear
}

.vjs-default-skin .vjs-controls {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0;
    padding: 0;
    height: 2.6em;
    color: #fff;
    border-top: 1px solid #404040;
    background: #242424;
    background: -moz-linear-gradient(top,#242424 50%,#1f1f1f 50%,#171717 100%);
    background: -webkit-gradient(linear,0% 0,0% 100%,color-stop(50%,#242424),color-stop(50%,#1f1f1f),color-stop(100%,#171717));
    background: -webkit-linear-gradient(top,#242424 50%,#1f1f1f 50%,#171717 100%);
    background: -o-linear-gradient(top,#242424 50%,#1f1f1f 50%,#171717 100%);
    background: -ms-linear-gradient(top,#242424 50%,#1f1f1f 50%,#171717 100%);
    background: linear-gradient(top,#242424 50%,#1f1f1f 50%,#171717 100%);
    /*visibility: hidden;
    opacity: 0*/
}
于 2012-11-14T18:12:13.840 回答