# live-player

实时音视频播放。该组件是原生组件,使用时请注意相关限制。
暂只针对国内主体如下类目的小程序开放,需要先通过类目审核,再在小程序管理后台,「开发」-「接口设置」中自助开通该组件权限。

一级类目/主体类型 二级类目 小程序内容场景
社交 直播 涉及娱乐性质,如明星直播、生活趣事直播、宠物直播等。选择该类目后首次提交代码审核,需经当地互联网主管机关审核确认,预计审核时长7天左右
教育 在线视频课程 网课、在线培训、讲座等教育类直播
医疗 互联网医院,公立医院 问诊、大型健康讲座等直播
金融 银行、信托、基金、证券/期货、证券、期货投资咨询、保险、征信业务、新三板信息服务平台、股票信息服务平台(港股/美股)、消费金融 金融产品视频客户理赔、金融产品推广直播等
汽车 汽车预售服务 汽车预售、推广直播
政府主体账号 / 政府相关工作推广直播、领导讲话直播等
工具 视频客服 不涉及以上几类内容的一对一视频客服服务,如企业售后一对一视频服务等
属性 类型 默认值 必填 说明 最低版本
src string 音视频地址。目前仅支持flv, rtmp格式 1.5.0
mode string live 模式 1.5.0
autoplay boolean false 自动播放 1.5.0
muted boolean false 是否静音 1.5.0
orientation string vertical 画面方向 1.5.0
object-fit string contain 填充模式,可选值有contain, fillCrop 1.5.0
min-cache number 1 最小缓冲区,单位s 1.5.0
max-cache number 3 最大缓冲区,单位s 1.5.0
sound-mode string speaker 声音输出方式 1.5.0
auto-pause-if-navigate boolean true 当跳转到其它小程序页面时,是否自动暂停本页面的实时音视频播放 1.5.0
auto-pause-if-open-native boolean true 当跳转到其它QQ原生页面时,是否自动暂停本页面的实时音视频播放 1.5.0
enable-metadata boolean false 是否回调metadata 1.17.0
bindstatechange eventhandle 播放状态变化事件,detail = {code} 1.5.0
bindfullscreenchange eventhandle 全屏变化事件,detail = {direction, fullScreen} 1.5.0
bindnetstatus eventhandle 网络状态通知,detail = {info} 1.5.0
bindmetadatachange eventhandle metadata通知,detail = {info} 1.17.0
# mode的合法值
说明 最低版本
live 直播 1.5.0
# orientation的合法值
说明 最低版本
vertical 竖直 1.5.0
horizontal 水平 1.5.0
# object-fit的合法值
说明 最低版本
contain 图像长边填满屏幕,短边区域会被填充黑色 1.5.0
fillCrop 图像铺满屏幕,超出显示区域的部分将被裁掉 1.5.0
# sound-mode的合法值
说明 最低版本
speaker 扬声器 1.5.0
# 状态码
代码 说明
2001 已经连接服务器
2002 已经连接服务器,开始拉流
2003 网络接收到首个视频数据包(IDR)
2004 视频开始播放
2006 视频播放结束
2007 视频播放Loading
2008 解码器启动
2009 视频分辨率改变
-2301 网络断连,且多次重连无效,更多重试请自行重启播放
-2302 获取加速拉流地址失败
2101 当前视频帧解码失败
2102 当前音频帧解码失败
2103 网络断连,已启动自动重连
2104 网络来包不稳。可能是下行带宽不足,或由于主播端出流不均匀
2105 当前视频播放出现卡顿
2106 硬解启动失败,采用软解
2107 当前视频帧不连续,可能丢帧
2108 当前流硬解第一个I帧失败,SDK自动切软解
3001 RTMP -DNS解析失败
3002 RTMP服务器连接失败
3003 RTMP服务器握手失败
3005 RTMP读/写失败
# 网络状态数据
键名 说明
videoBitrate 当前视频数据接收比特率,单位: kbps
audioBitrate 当前音频数据接收比特率,单位: kbps
videoFPS 当前视频帧率
videoGOP 当前视频GOP,也就是每两个关键帧(I帧)间隔时长,单位: s
netSpeed 当前的发送/接收速度
netJitter 网络抖动情况,抖动越大,网络越不稳定
videoWidth 视频画面的宽度
videoHeight 视频画面的高度
# Bug & Tip
  1. tip: live-player默认宽度300px、高度225px,可通过qss设置宽高。
  2. tip: 开发者工具上暂不支持。
# 示例代码
<live-player id="playerid" src="https://domain/pull_stream" mode="live" autoplay bindstatechange="statechange" binderror="error" />
1
Page({
  statechange(e) {
    console.log('live-player code:', e.detail.code)
  },
  error(e) {
    console.error('live-player error:', e.detail.errMsg)
  }
})
1
2
3
4
5
6
7
8