LaughingZhu's Blog
LaughingZhu
Make or miss win or lose I put my name on it
管理
文章
Comment

Videojs视频开发技巧记录

LaughingZhu
March 4, 2021
245 views
1888 words
No comments

Videojs官网,video.js是一款基于HTML5的网络视频播放器。它支持HTML5和Flash视频,以及YouTube和Vimeo(通过插件),支持在桌面和移动设备上播放视频。


这次要做一个在线直播课h5的项目,需求是可以支持在线直播推流和查看回放的功能,总部给了两种推流的格式:rtmp和http(m3u8),由于该项目主要运行环境是微信里(移动端),而移动端不支持flash的缘故(rtmp推流需要flash的支持),所以使用了http(m3u8),.m3u8原生的Video标签就支持的,所以其实使用videojs与否都可以实现项目的需求。我接着这次项目的机会顺便了解一下videojs的心态使用了videojs,这里推荐另一个视频的库Plyr,也听不错的,其实在移动h5里我觉的都差不多,这些库也是基于原生video标签封装。

1.初始化

1.JS方式(React)

// 安装
# npm install --save-dev video.js

import videojs from "video.js";
import videozhCN from "video.js/dist/lang/zh-CN.json";   // 中文语言
import "video.js/dist/video-js.css";    //默认的样式

/*初始化播放器▶️*/
const videoJsOptions = {
  autoplay: true,  // 自动播放
  language: "zh-CN",   // 这样写好像不管用,需要import上边的"video.js/dist/lang/zh-CN.json"
  playsinline: true,    // 禁止IOS端自动播放
  liveui: true ,
  preload: "auto",  // 自动加载
  fluid: true,  // 跟随外层容器变化大小,跟随的是外层宽度
  sources: [{
    src: '.m3u8的视频流链接',
    type: "application/x-mpegURL",
  }],
};
videojs.addLanguage("zh-CN", videozhCN);
    player: videojs('detail-video', videoJsOptions , function onPlayerReady() { // (id或者refs获取节点,options,回调函数)
    this.play();
  })    
}

<div className="detail-video" id='detail-video'></div>



2.标签方式
一种是在<video>标签里面加上class="video-js"data-setup='{}'属性。注意,两者缺一不可。

2.播放按钮居中

video.js默认的播放按钮在左上角,应该是 video.js 开发人员认为放中间会遮挡内容,所以没放中间。
不过我们常见的一般都在中间,比较符合习惯。
这是可以通过参数修改的,在<video>标签中加入vjs-big-play-centered类,就可以了。
像这样:    class="video-js vjs-big-play-centered"

3.禁止在iPhone safari中自动全屏

方法如下,在<video>标签中加入playsinline参数,

注意,在iOS10之前用的是webkit-playsinline

4.暂停时显示播放按钮

video.js 在未播放时,会显示一个大的播放按钮,上面我们提到如何让他居中。
那么,如何在视频暂停时也显示这个播放按钮呢?
QQ截图20170308103219.png


有很多用JS的解决办法,感觉都挺麻烦的。
其实用CSS就可以搞定了:
.vjs-paused .vjs-big-play-button,
.vjs-paused.vjs-has-started .vjs-big-play-button {
    display: block;
}
是不是很轻便很简单 :)

5.播放按钮变○圆形

video.js 默认的播放按钮是圆角矩形,
我们一般更熟悉播放按钮为圆形的:
unnamed-file.png
那么怎么改呢?还是用CSS来解决。

.video-js .vjs-big-play-button{
    font-size: 2.5em;
    line-height: 2.3em;
    height: 2.5em;
    width: 2.5em;
    -webkit-border-radius: 2.5em;
    -moz-border-radius: 2.5em;
    border-radius: 2.5em;
    background-color: #73859f;
    background-color: rgba(115,133,159,.5);
    border-width: 0.15em;
    margin-top: -1.25em;
    margin-left: -1.75em;
}
/* 中间的播放箭头 */
.vjs-big-play-button .vjs-icon-placeholder {
    font-size: 1.63em;
}
/* 加载圆圈 */
.vjs-loading-spinner {
    font-size: 2.5em;
    width: 2em;
    height: 2em;
    border-radius: 1em;
    margin-top: -1em;
    margin-left: -1.5em;
}


因为原来居中的时候宽度和高度改变了,所以margin的值也要相应改变

6.点击屏幕播放/暂停

这个是视频播放的时候用得较多的功能,解决方法如下。
.video-js.vjs-playing .vjs-tech {
    pointer-events: auto;
}
pointer-events是CSS的一个属性,用来控制鼠标的动作,具体可参考《CSS里的pointer-events属性》。

7.重载视频

总有那么一些情形,我们需要 video.js 重新载入视频文件。
比如,立即播放刚上传的文件。
例如这样的标签:

<video id="example_video">
    <source id="videoMP4" src="1.mp4" />
</video>
<button id="reload">重载</button>
在video.js中,用现成的js方法就可以实现:

var video = document.getElementById('example_video');
var source = document.getElementById('videoMP4');
$("#reload").click(function() {
    video.pause()
    source.setAttribute('src', '2.mp4');
    video.load();
    video.play();
});
或者:

var video = document.getElementById('example_video');
$("#reload").click(function() {
    video.pause()
    video.setAttribute('src', '2.mp4');
    video.load();
    video.play();
});


我用的是动态创建视频DOM
注:(忘了开始使用的是什么方法了吗,但是会出现多个视频Dom,出现多个视频窗口,所以切换视频的时候动态添加更换)
如下:

var newVideo = document.createElement("div");//创建一个标签        
newVideo.innerHTML = `
    <video id="my-video"
    class="video-js
    vjs-default-skin
    vjs-big-play-centered" 
    poster=${require("@/assets/live-bg.png")}
    controls
    preload="auto"></video>`;
var Fid = document.getElementById('detail-video');
//通过id号获取newVideo的父节点(也就是上一级的节点)
Fid.appendChild(newVideo);//把创建的节点newVideo添加到父节点中;

8.进度显示当前播放时间

video.js 默认倒序显示时间,也就是视频播放的剩余时间。
要显示当前的播放时间,以及总共视频时长,加2行CSS解决:
.video-js .vjs-time-control{display:block;}
.video-js .vjs-remaining-time{display: none;}

Popular artivles
Blog Info
Posts Num
Comments Num
0
Operating Days
NaN M NaN D
Last activity
Invalid Date