flv.js使用

H5中使用

<!DOCTYPE html>
<html lang="zh-CN">

<head>
  <meta charset="UTF-8" />
  <title>demo</title>
  <meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1" />
  <meta name="renderer" content="webkit" />
  <base target="_blank" />
</head>
</head>

<body style="margin-top:50px">
  <div class="w100 flex" style="height: 80px">
    <video id="id1" preload="auto" muted autoplay type="rtmp/flv">
      <source src="">
    </video>
  </div>

  <script src="./flv.min.js"></script>
  <script>
    videoElement = document.getElementById('id1');
    let url = "xxx"; // flv视频流地址
    if (flvjs.isSupported()) {
      flvPlayer = flvjs.createPlayer({
        type: 'flv',					//媒体类型
        url: url,					//flv格式媒体URL
        isLive: true,					//数据源是否为直播流
        hasAudio: false,				//数据源是否包含有音频
        hasVideo: true,					//数据源是否包含有视频
        enableStashBuffer: false		//是否启用缓存区
      }, {
        enableWorker: false, 			//不启用分离线程
        enableStashBuffer: false, 		//关闭IO隐藏缓冲区
        autoCleanupSourceBuffer: true 	//自动清除缓存
      });
      flvPlayer.attachMediaElement(videoElement);	//将播放实例注册到节点
      flvPlayer.load(); 					//加载数据流
      flvPlayer.play();					//播放数据流
    }
  </script>
</body>

</html>

flv.js及flv.min.js文件

链接:[https://pan.baidu.com/s/1JhnpoLYQ_sL4lTxxz4B_Lw]
提取码:tx0l

vue中使用

安装flv.js
html
<video
 :id="form.videoId"
 autoplay
 playsinline
 muted
 webkit-playsinline="true"
 controls
></video>
js
import FlvPlayer from "flv.js";


    close() {
      this.player.pause();
      this.player.unload();
      this.player.detachMediaElement();
      this.player.destroy();
      this.player = null;
    },
    async initPlayer(url, index) {
      var videoElement = document.getElementById("id"); // 获取到html中的video标签
      console.log(videoElement, "videoElement");
      FlvPlayer.isSupported() && (await FlvPlayer.getFeatureList());
      this.player = FlvPlayer.createPlayer({
        type: "flv",
        url: url,
        // hasAudio: true,
      });

      // 设置视频元素
      this.player.attachMediaElement(videoElement);
      // 监听播放器就绪事件
      let that = this;
      that.loading = true;
      this.player.on(FlvPlayer.Events.MEDIA_INFO, (info) => {
        // 在此可以做一些播放器初始化后的操作
        console.log("info", info);
        that.loading = false;
      });
      // 监听错误事件
      this.player.on(FlvPlayer.Events.ERROR, (type, details) => {
        console.log(`FLV.js 报错: ${type}`, details);
        that.loading = false;
        // that.close(index);
        // 根据错误类型和详情进行相应处理
        switch (type) {
          case FlvPlayer.ErrorTypes.NETWORK_ERROR:
            // 网络错误处理
            break;
          case FlvPlayer.ErrorTypes.MEDIA_ERROR:
            // 媒体错误处理
            break;
          case FlvPlayer.ErrorTypes.IO_ERROR:
            // 输入/输出错误处理
            break;
          default:
          // 其他错误处理
        }
      });

      // 加载和播放视频
      this.player.load();
      this.player.play();
    },
  • 9
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值