加载视频流实现直播功能

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

加载视频流实现直播功能

周小盗   2022-06-03 我要评论

前言

最近在项目中有一个播放监控站点图像视频的功能(类似与直播),然后对此进行了一个记录与总结!

在此功能中,后台本来给的是rtmp格式的视频流,后在网上找了几种方式,发现rtmp视频流需要使用flash播放器,然而各大主流浏览器已经放弃flash,因此最后又改用hls格式的视频流,最终完成这个功能!(如果只是想要成功的代码,请直接看:三、vue加载hls视频流)

一、视频流是什么?

  • 视频流:视频流其实就是流媒体(streaming media),是指将一连串数据压缩后,经过网络分段发送,即时传输以供观看音视频的一种技术。监控、直播等实时播放的功能一般都使用的是流媒体。
  • 流媒体协议:流媒体协议是一种标准化的传递方法,用于将视频分解为多个块,将其发送给视频播放器,播放器重新组合播放,常见的有rtmp、hls、hds、mss、MPEG-DASH等。
  • 视频格式(format):视频格式指视频文件格式(container format)。常见 container format 包括 .mp4、.m4v、.avi、.mov等。

三种定义在这里不做过多赘述,有想深入了解的小伙伴可以自己再去了解一下;rtmp视频流实际上就是以rtmp流媒体协议生成的流媒体;hls视频流同理(这个视频流的格式一般由后台进行控制)

二、vue加载rtmp视频流

1.方法一:video.js

npm install --save vue-video-player
npm install --save videojs-flash
<template>
    <div class="box">
        <section id="video" class="video-js vjs-default-skin" ref="viodeRef"></section>
    </div>
</template>
<script>
    import Video from 'video.js'
    import 'video.js/dist/video-js.min.css'
  export default {
    name: 'video-play-box',
    mounted(){
      this.player = Video('video', {
        //确定播放器是否具有用户可以与之交互的控件。没有控件,启动视频播放的唯一方法是使用autoplay属性或通过Player API。
        controls: true,
        //自动播放属性,muted:静音播放
        muted: false,
        autoplay: true,
        //建议浏览器是否应在<video>加载元素后立即开始下载视频数据。
        preload: "auto",
        //设置视频播放器的显示宽度(以像素为单位)
        width: "800px",
        //设置视频播放器的显示高度(以像素为单位)
        height: "500px",
        // poster: 'https://static.shuxuejia.com/img/video_image.png', // 封面图片
        sources: [{
          src:"rtmp://58.200.131.2:1935/livetv/cctv3",
          type:'video/rtmp'
        }],
            
        playbackRates: [0.5, 1, 1.5, 2] //倍速播放
      }, function onPlayerReady() {
        Video.log('Your player is ready!'); // 比如: 播放量+1请求
        this.on('ended', function() {
          Video.log('Awww...over so soon?!');
        });
      });
      // this.myPlayer.src('rtmp://10.15.3.31:1935/live/openUrl/QUDplmM')
      // this.myPlayer.load('rtmp://10.15.3.31:1935/live/openUrl/QUDplmM')
        },
    beforeDestroy() {
      if (this.player) {
        this.player.dispose()
      }
    },
        
  }
</script>
<style scoped lang="scss">
.box{
    width:100%;
    height:100%;
    display:flex;
    align-items: center;
    justify-content: center;
    .video{
        margin:0 auto;
    }
}
</style>

2.方法二:ckplayer

因为本人已经尝试过由于flash原因不可用,所以已经都删掉了,没有部分截图,就文字描述一下,感兴趣的小伙伴可以自己搜一下。

  • 第一步:官网下载ckplayer
  • 第二步:将下载好的文件夹解压后放到项目中的static(静态资源文件夹)下
  • 第三步:在index.html中对应引入ckplayer.js文件
  • 第四步:创建播放视频的vue文件,代码如下: 
<template>
  <div>
    <label>ckplayer播放器插件Vue使用Demo</label>
    <div id="video"></div>
  </div>
</template>
<script>
export default {
  name: 'ckplayerPlugin',
  data () {
    return {
    }
  },
  mounted: function(){
    // 挂载完成后进行
    var videoObject = {
                container: '#video', //容器的ID或className
                variable: 'player', //播放函数名称
                loaded: 'loadedHandler', //当播放器加载后执行的函数
                loop: true, //播放结束是否循环播放
                cktrack: 'static/ckplayer/material/srt.srt', //字幕文件
                poster: 'static/ckplayer/material/poster.jpg', //封面图片
                preview: { //预览图片
                    file: ['static/ckplayer/material/mydream_en1800_1010_01.png', 'static/ckplayer/material/mydream_en1800_1010_02.png'],
                    scale: 2
                },
                config: '', //指定配置函数
                debug: true, //是否开启调试模式
                drag: 'start', //拖动的属性
                seek: 0, //默认跳转的时间
                //广告部分开始
                adfront: 'http://×××w.ckplayer.com/yytf/swf/front001.swf,http://×××w.ckplayer.com/yytf/swf/front002.swf', //前置广告
                adfronttime: '15,15',
                adfrontlink: '',
                adpause: 'http://×××w.ckplayer.com/yytf/swf/pause001.swf,http://×××w.ckplayer.com/yytf/swf/pause002.swf',
                adpausetime: '5,5',
                adpauselink: '',
                adinsert: 'http://×××w.ckplayer.com/yytf/swf/insert001.swf,http://×××w.ckplayer.com/yytf/swf/insert002.swf',
                adinserttime: '10,10',
                adinsertlink: '',
                inserttime: '10,80',
                adend: 'http://×××w.ckplayer.com/yytf/swf/end001.swf,http://×××w.ckplayer.com/yytf/swf/end002.swf',
                adendtime: '15,15',
                adendlink: '',
                //广告部分结束
                promptSpot: [ //提示点
                    {
                        words: '提示点文字01',
                        time: 30
                    },
                    {
                        words: '提示点文字02',
                        time: 150
                    }
                ],
                video: [
                    ['http://img.ksbbs.com/asset/Mon_1703/05cacb4e02f9d9e.mp4', 'video/mp4', '中文标清', 0],
                    ['http://img.ksbbs.com/asset/Mon_1703/d0897b4e9ddd9a5.mp4', 'video/mp4', '中文高清', 0],
                    ['http://img.ksbbs.com/asset/Mon_1703/eb048d7839442d0.mp4', 'video/mp4', '英文高清', 10],
                    ['http://img.ksbbs.com/asset/Mon_1703/d30e02a5626c066.mp4', 'video/mp4', '英文超清', 0]
                ]
            };
      // 定义一个对象
      var player = new ckplayer(videoObject);
  }
}
</script>
<style scoped>
  #video {
    width: 600px;
    height: 400px;
    margin: 0px auto;
  }
</style>

总结:经检验,以上两种方法加载均需要flash的支持,然而目前大众浏览器均已放弃flash,所以建议使用下方hls视频流播放;

三、vue加载hls视频流

1.index.html中

添加:

<script src="https://cdn.jsdelivr.net/npm/hls.js@latest"></script>

2.video-player.vue文件

<template>
  <div class="hls">
    <video id="video" muted></video>
  </div>
</template>
<script>
export default {
  name: 'hls-video',
  components: {
  },
  data() {
    return{
        video:null,
        hls:null
    }
  },
  props: {
    selectStdInfo:{
      type:Object,
      required:true
    }
  },
  watch:{
    // 视频弹窗时如果弹窗已存在,重新加载视频流
    "selectStdInfo.mourl":function(oldV,newV){
      if(newV!=oldV){
        this.initVideo()
      }
    }
  },
  mounted() {
    this.initVideo()
  },
  destroyed(){
    this.reset()
  },
  methods: {
        //组件销毁时,调用该方法,停止请求;detachMedia和stopLoad为hls官网方法
      reset(){
          this.hls.detachMedia(this.video)
          this.hls.stopLoad()   
      },
      //初始化video  
      initVideo () {       
          this.video = document.getElementById('video')
          // 浏览器是否支持hls 
          if(Hls.isSupported()) {
             //如果hls已存在,先清空
             if(this.hls){
                this.reset()
              }else{
                this.hls = new Hls()
              }
              //this.selectStdInfo.mourl为父组件传给该子组件的视频url
              this.hls.loadSource(this.selectStdInfo.mourl)
              this.hls.attachMedia(this.video)
              this.hls.on(Hls.Events.MANIFEST_PARSED,()=>{
                this.video.play()
              });
          }else if (video.canPlayType('http://kbs-dokdo.gscdn.com/dokdo_300/_definst_/dokdo_300.stream/playlist.m3u8')) {
            // 不支持hls ,支持苹果原生 
              this.video.src = ''
               this.video.addEventListener('loadedmetadata',function() {
                this.video.play()
           })
         }
      }
  },
}
</script>
<style scoped lang="scss">
.hls{
    width:100%;
    height:100%;
    display:flex;
    align-items: center;
    justify-content: center;
    #video{
    width:100%;
        margin:0 auto;
    }
}
</style>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们