首页 > 网站 > 帮助中心 > 正文

详解vue2.0+vue-video-player实现hls播放全过程

2024-07-09 22:41:09
字体:
来源:转载
供稿:网友

起因

最近公司想做一套视频点播服务,因为考虑到成本问题,领导希望一切都用开源系统来完成。基于这个出发点,那就肯定排除了各大云视频平台(腾讯云 音视频点播VOD、网易云视频、七牛云、阿里云 视频服务等)。其实这里我还是建议购买云视频平台,因为自己造轮子肯定没有别人造的好(专门研发团队除外、以此业务为生的公司除外),再说,云视频平台服务商提供的都是一整套解决方案:收集、存储、转码、播放器等,并且在cdn和弹性扩容上都能得到最大保障。

准备

视频点播最少需要两样东西:流媒体服务、视频播放器。 因为这是一篇讲述前端播放器的帖子,关于流媒体服务的搭建我就pass了,以后有时间再补充新帖。

因为公司前端架构用的是vue全家桶,所以还是希望能够找一款基于vue封装的视频播放器。

首先到vue社区找到了vue-dplayer,于是就install到本地测试了一下,这时候出现个问题:此播放器在播放基于hls协议的m3u8文件时(视频文件在流媒体服务已经成功部署),在ios上能够正常播放(自家协议支持良好),但是在pc的chrome上是不支持的。然后我去github上找了找资料,资料显示Dplay(vue-dplayer就是依据Dplay封装的)是支持hls的,只是需要引入hls.js,然后用hls对video对象进行处理。因为hls.js与Dplayer示例代码是针对video对象处理的,引入到项目中还需要修改vue-dplayer的一个属性,时间紧迫,先放弃之(之后我会有一篇专门介绍Dplayer播放hls的帖子,已补充),转身投入vue-video-player的怀抱。

为什么会用vue-video-player

1. 我搭建的流媒体服务的管理页面内的播放器就是用的videoJs(vue-video-player是依据videoJs封装的),使用之后感觉良好。
2. 百度输入“vue video”,vue-video-player就在顶部。(哈哈,就是这么随意)
3. 当然还是看了demo页,支持的协议齐全。
4. 虽然vue-video-player的github上还有些issues没有关闭,但是自己觉得守着videoJs强大的库与万千使用者,总能解决问题。(迷之自信啊)

开整

安装依赖

npm install vue-video-player --save

引入样式

// 第一个是videoJs的样式,后一个是vue-video-player的样式,因为考虑到我其他业务组件可能也会用到视频播放,所以就放在了main.js内require('video.js/dist/video-js.css')require('vue-video-player/src/custom-theme.css')

把VueVideoPlayer导入并挂在到vue上

//在main.js内import VideoPlayer from 'vue-video-player'Vue.use(VideoPlayer);

编写业务组件 myPlayer.vue

<template> <div class="container"> <div class="player">  <video-player class="video-player vjs-custom-skin"      ref="videoPlayer"      :playsinline="true"      :options="playerOptions"      @play="onPlayerPlay($event)"      @pause="onPlayerPause($event)"  >  </video-player> </div> </div></template><script>import { videoPlayer } from 'vue-video-player';export default { data () { return {  playerOptions: {//  playbackRates: [0.7, 1.0, 1.5, 2.0], //播放速度  autoplay: false, //如果true,浏览器准备好时开始回放。  muted: false, // 默认情况下将会消除任何音频。  loop: false, // 导致视频一结束就重新开始。  preload: 'auto', // 建议浏览器在<video>加载元素后是否应该开始下载视频数据。auto浏览器选择最佳行为,立即开始加载视频(如果浏览器支持)  language: 'zh-CN',  aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9"或"4:3")  fluid: true, // 当true时,Video.js player将拥有流体大小。换句话说,它将按比例缩放以适应其容器。  sources: [{   type: "application/x-mpegURL",   src: "video.m3u8" //你的m3u8地址(必填)  }],  poster: "poster.jpg", //你的封面地址  width: document.documentElement.clientWidth,  notSupportedMessage: '此视频暂无法播放,请稍后再试', //允许覆盖Video.js无法播放媒体源时显示的默认信息。//  controlBar: {//   timeDivider: true,//   durationDisplay: true,//   remainingTimeDisplay: false,//   fullscreenToggle: true //全屏按钮//  }  } } }, components: { videoPlayer }, methods: { onPlayerPlay(player) {  alert("play"); }, onPlayerPause(player){  alert("pause"); }, }, computed: { player() {  return this.$refs.videoPlayer.player } }}</script><!-- Add "scoped" attribute to limit CSS to this component only --><style type="text/css" scoped> .container { background-color: #efefef; min-height: 100%; }</style>
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表