当前位置 主页 > 服务器问题 > win服务器问题汇总 >

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

    栏目:win服务器问题汇总 时间:2019-11-06 20:34

    起因

    最近公司想做一套视频点播服务,因为考虑到成本问题,领导希望一切都用开源系统来完成。基于这个出发点,那就肯定排除了各大云视频平台(腾讯云 音视频点播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>