博客
关于我
腾讯TcPlayer listener函数监听
阅读量:126 次
发布时间:2019-02-26

本文共 1009 字,大约阅读时间需要 3 分钟。

触发条件

从指定的直播地址进行拉流

使用腾讯云的TcPlayer播放器

在网站允许flash的情况下,如果指定的直播地址提供了flv格式的流源,则优先使用flash播放器

播放器被隐藏(display:none)

问题描述

使用腾讯云的TcPlayer从指定的直播地址拉流时,可以在初始化播放器时设置一个listener方法,用于监听流的拉取状态

在刚开始时播放器会被设置为display:none隐藏起来,原因是需要先展示一个未开始播放的状态,待拉取流成功后再进行播放器的展示

此时(播放器被隐藏)的情况下,如果采用h5的video播放方式的m3u8流,能够正常地通过listener函数监听到流的状态

但如果使用flv格式的流源进行播放,由于flash技术的特性,listener函数将无法接收到流的状态信息,必须移除display:none才可以正常监听

listener函数的实现代码示例:listener: function (msg) {    if (msg.type == 'error') {        console.log(msg, '播放报错');        _this.$emit('update-stream-state', 3);        //尝试5次拉流        if (_this.player) {            timer = setTimeout(() => {                _this.player && _this.player.load();                console.log('重试拉流');            }, 5000);            setInterval(() => {                clearTimeout(timer);            }, 25000);        }    } else if (msg.type == 'play') {        console.log(msg, '拉流成功');        //清除拉流的定时器        clearTimeout(timer);        _this.$emit('update-stream-state', 1);    }}

转载地址:http://izof.baihongyu.com/

你可能感兴趣的文章
Non-final field ‘code‘ in enum StateEnum‘
查看>>
none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
查看>>
None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
查看>>
NOPI读取Excel
查看>>
NoSQL&MongoDB
查看>>
NoSQL介绍
查看>>
Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
Notepad++在线和离线安装JSON格式化插件
查看>>
notepad++最详情汇总
查看>>
notepad如何自动对齐_notepad++怎么自动排版
查看>>
Notification 使用详解(很全
查看>>
NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
查看>>
Now trying to drop the old temporary tablespace, the session hangs.
查看>>
nowcoder—Beauty of Trees
查看>>
np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
查看>>
np.power的使用
查看>>
NPM 2FA双重认证的设置方法
查看>>
npm build报错Cannot find module ‘webpack‘解决方法
查看>>
npm ERR! ERESOLVE could not resolve报错
查看>>
npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
查看>>