美文网首页
vue中在实现自适应视频播放器

vue中在实现自适应视频播放器

作者: Rascar | 来源:发表于2020-05-11 17:48 被阅读0次

    1.先安装npm install vue-video-player --save

    1. 在main.js入口文件中引入
    import VideoPlayer from 'vue-video-player'
    require('video.js/dist/video-js.css')
    require('vue-video-player/src/custom-theme.css')
    Vue.use(VideoPlayer
    

    3.在组件中使用

    <video-player  class="video-player vjs-custom-skin"
      ref="videoPlayer" 
      :playsinline="true" 
      :options="playerOptions"
      @play="onPlayerPlay($event)" 
      @pause="onPlayerPause($event)" 
      @statechanged="playerStateChanged($event)"
      @loadeddata="onPlayerLoadeddata($event)"
      @timeupdate="onPlayerTimeupdate($event)" 
    
    ></video-player>
    
    export default {
      data(){
    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: "",//这里的种类支持很多种:基本视频格式、直播、流媒体等,具体可以参看git网址项目
          src: "" //url地址
        }],
        poster: "../../static/images/test.jpg", //你的封面地址
        // width: document.documentElement.clientWidth, //播放器宽度
        notSupportedMessage: '此视频暂无法播放,请稍后再试', //允许覆盖Video.js无法播放媒体源时显示的默认信息。
        controlBar: {
          timeDivider: true,
          durationDisplay: true,
          remainingTimeDisplay: false,
          fullscreenToggle: true  //全屏按钮
        }
    }
    }
    }
    

    5.调用

    methods:{
      onPlayerPause (player) {
          //监听暂停
          console.log('暂停');
          // 暂停时时间
          console.log(player.duration());
          this.$emit('onPlayerPauseFun', player);
        },
    
    videoUrl(val) {
          if (val !== '') {
            this.$refs.videoPlayer.player.src(val)
            
          }
        },
        poster(n, o) {
          if(n) {
            this.$refs.videoPlayer.player.poster(n);
          }
        },
    
    }

    相关文章

      网友评论

          本文标题:vue中在实现自适应视频播放器

          本文链接:https://www.haomeiwen.com/subject/itcpnhtx.html