首页 > 其他分享 >live-pusher

live-pusher

时间:2024-12-29 18:24:32浏览次数:8  
标签:1.7 false string pusher number live boolean 推流

live-pusher

基础库 1.7.0 开始支持,低版本需做兼容处理

小程序插件:支持,需要小程序基础库版本不低于 2.3.0

微信 Windows 版:支持

微信 Mac 版:支持

微信 鸿蒙 OS 版:支持

相关文档: wx.createLivePusherContext

渲染框架支持情况:Skyline (使用最新 Nighly 工具调试)、WebView

功能描述

实时音视频录制(v2.9.1 起支持同层渲染)。需要用户授权 scope.camerascope.record

申请开通

暂只针对国内主体如下类目的小程序开放,需要先通过类目审核,再在小程序管理后台,「开发」-「接口设置」中自助开通该组件权限。

一级类目/主体类型 二级类目 小程序内容场景
社交 直播 涉及娱乐性质,如明星直播、生活趣事直播、宠物直播等。选择该类目后首次提交代码审核,需经当地互联网主管机关审核确认,预计审核时长7天左右
教育 在线视频课程 网课、在线培训、讲座等教育类直播
医疗 互联网医院,公立医疗机构,其他私立医疗机构 问诊、大型健康讲座等直播
金融 银行、信托、公募基金、私募基金、证券/期货、证券、期货投资咨询、保险、征信业务、新三板信息服务平台、股票信息服务平台(港股/美股)、消费金融、融资担保 金融产品视频客服理赔、金融产品推广直播等
汽车 汽车预售服务 汽车预售、推广直播
政府主体账号 / 政府相关工作推广直播、领导讲话直播等
IT科技 多方通信;音视频设备 为多方提供电话会议/视频会议等服务;智能家居场景下控制摄像头
房地产服务 房地产营销 房地产营销直播服务、在线音视频带看等
商业服务 公证 在线业务办理等

通用属性

属性 类型 默认值 必填 说明 最低版本
url string 推流地址。目前仅支持 rtmp 格式 1.7.0
mode string RTC 模式 1.7.0
合法值说明最低版本QVGAQuarter VGA3.5.0HVGAHalf-size VGA3.5.0SD标清1.7.0HD高清1.7.0FHD超清1.7.0RTC实时通话1.7.0
autopush boolean false 自动推流 1.7.0
enableVideoCustomRender boolean false 自定义渲染,允许开发者自行处理所采集的视频帧,详见LivePusherContext 2.29.0
muted boolean false 是否静音。即将废弃,可用 enable-mic 替代 1.7.0
enable-camera boolean true 开启摄像头 1.7.0
auto-focus boolean true 自动聚集 1.7.0
orientation string vertical 画面方向 1.7.0
合法值说明vertical竖直horizontal水平
beauty number 0 美颜,取值范围 0-9 ,0 表示关闭。鸿蒙 OS 暂不支持 1.7.0
whiteness number 0 美白,取值范围 0-9 ,0 表示关闭 1.7.0
aspect string 9:16 宽高比,可选值有 3:4, 9:16 1.7.0
min-bitrate number 200 最小码率 1.7.0
max-bitrate number 1000 最大码率 1.7.0
audio-quality string high 高音质(48KHz)或低音质(16KHz),值为high, low 1.7.0
waiting-image string 进入后台时推流的等待画面 1.7.0
waiting-image-hash string 等待画面资源的MD5值 1.7.0
zoom boolean false 调整焦距 2.1.0
device-position string front 前置或后置,值为front, back 2.3.0
background-mute boolean false 进入后台时是否静音(已废弃,默认退后台静音) 1.7.0
mirror boolean false 设置推流画面是否镜像,产生的效果在 live-player 反应到 2.7.0
remote-mirror boolean false 同 mirror 属性,后续 mirror 将废弃 2.10.0
local-mirror string auto 控制本地预览画面是否镜像 2.10.0
合法值说明auto前置摄像头镜像,后置摄像头不镜像enable前后置摄像头均镜像disable前后置摄像头均不镜像
audio-reverb-type number 0 音频混响类型 2.10.0
合法值说明0关闭1KTV2小房间3大会堂4低沉5洪亮6金属声7磁性
enable-mic boolean true 开启或关闭麦克风 2.10.0
enable-agc boolean false 是否开启音频自动增益 2.10.0
enable-ans boolean false 是否开启音频噪声抑制 2.10.0
audio-volume-type string auto 音量类型 2.10.0
合法值说明auto自动media媒体音量voicecall通话音量
video-width number 360 上推的视频流的分辨率宽度 2.10.0
video-height number 640 上推的视频流的分辨率高度 2.10.0
beauty-style string smooth 设置美颜类型。鸿蒙 OS 暂不支持 2.12.0
合法值说明smooth光滑美颜nature自然美颜
filter string standard 设置色彩滤镜 2.12.0
合法值说明standard标准pink粉嫩nostalgia怀旧blues蓝调romantic浪漫cool清凉fresher清新solor日系aestheticism唯美whitening美白cerisered樱红
picture-in-picture-mode string/Array 设置小窗模式: push, pop,空字符串或通过数组形式设置多种模式(如: ["push", "pop"]) 2.25.0
合法值说明[]取消小窗push路由 push 时触发小窗pop路由 pop 时触发小窗
voice-changer-type number 0 0:关闭变声;1:熊孩子;2:萝莉;3:大叔;4:重金属;6:外国人;7:困兽;8:死肥仔;9:强电流;10:重机械;11:空灵 2.31.0
custom-effect boolean false 是否启动自定义特效,设定后不能更改 2.29.1
skin-whiteness number 0 自定义特效美白效果,取值 0~1。需要开启 custom-effect 2.29.1
skin-smoothness number 0 自定义特效磨皮效果,取值 0~1。需要开启 custom-effect 2.29.1
face-thinness number 0 自定义特效瘦脸效果,取值 0~1。需要开启 custom-effect 2.29.1
eye-bigness number 0 自定义特效大眼效果,取值 0~1。需要开启 custom-effect 2.29.1
fps number 15 帧率,有效值为 1~30 2.31.0
bindstatechange eventhandle 状态变化事件,detail = 1.7.0
bindnetstatus eventhandle 网络状态通知,detail = 1.9.0
binderror eventhandle 渲染错误事件,detail = 1.7.4
bindbgmstart eventhandle 背景音开始播放时触发 2.4.0
bindbgmprogress eventhandle 背景音进度变化时触发,detail = 2.4.0
bindbgmcomplete eventhandle 背景音播放完成时触发 2.4.0
bindaudiovolumenotify eventhandle 返回麦克风采集的音量大小 2.12.0
bindenterpictureinpicture eventhandler 进入小窗 2.25.0
bindleavepictureinpicture eventhandler 退出小窗 2.25.0

Bug & Tip

  1. tip:开发者工具上暂不支持。
  2. tiplive-pusher 默认宽度为100%、无默认高度,请通过wxss设置宽高。
  3. tipwaiting-image 属性在 2.3.0 起完整支持网络路径、临时文件和包内路径。
  4. tip:请注意原生组件使用限制
  5. tip: 相关介绍和原理可参考此文章

错误码(errCode)

代码 说明
10001 用户禁止使用摄像头
10002 用户禁止使用录音
10003 背景音资源(BGM)加载失败
10004 等待画面资源(waiting-image)加载失败

状态码(code)

代码 说明
1001 推流:已经连接推流服务器
1002 推流:已经与服务器握手完毕,开始推流
1003 推流:打开摄像头成功
1004 推流:录屏启动成功
1005 推流:推流动态调整分辨率
1006 推流:推流动态调整码率
1007 推流:首帧画面采集完成
1008 推流:编码器启动
1018 推流:进房成功(ROOM协议特有)
1019 推流:退房成功(ROOM协议特有有)
1020 推流:远端主播列表变化(ROOM协议特有)
1021 推流:网络变更时重进房,WiFi 切换到4G 会触发断线重连(ROOM协议特有)
1022 推流:进入房间失败(ROOM协议特有)
1031 推流:远端主播进房通知(ROOM协议特有)
1032 推流:远端主播退房通知(ROOM协议特有)
1033 推流:远端主播视频状态位变化(RROOM协议特有)
1034 推流:远端主播音频状态位变化(ROOM协议特有)
1101 推流:网络状况不佳:上行带宽太小,上传数据受阻
1102 推流:网络断连, 已启动自动重连
1103 推流:硬编码启动失败, 采用软编码
1104 推流:视频编码失败, 内部会重启编码器
3001 推流:RTMP DNS解析失败
3002 推流:RTMP服务器连接失败
3003 推流:RTMP服务器握手失败
3004 推流:RTMP服务器主动断开,请检查推流地址的合法性或防盗链有效期
3005 推流:RTMP 读/写失败
4998 Mic状态切换的时候,enable-mic触发(iOS特有)
4999 mute状态切换的时候,muted 触发(iOS特有)
5001 系统电话打断或者微信音视频电话打断
10001 用户禁止使用摄像头
10002 用户禁止使用录音
10003 背景音资源(BGM)加载失败
10004 等待画面资源(waiting-image)加载失败
-1301 推流:打开摄像头失败
-1302 推流:打开麦克风失败
-1303 推流:视频编码失败
-1304 推流:音频编码失败
-1305 推流:不支持的视频分辨率
-1306 推流:不支持的音频采样率
-1307 推流:网络断连,且经多次重连抢救无效,更多重试请自行重启推流
-1308 推流:开始录屏失败,可能是被用户拒绝
-1309 推流:录屏失败,不支持的Android系统版本,需要5.0以上的系统
-1310 推流:录屏被其他应用打断了
-1311 推流:Android Mic打开成功,但是录不到音频数据
-1312 推流:录屏动态切横竖屏失败
0 无错误

网络状态数据(info)

键名 说明
videoBitrate 当前视频编/码器输出的比特率,单位 kbps
audioBitrate 当前音频编/码器输出的比特率,单位 kbps
videoFPS 当前视频帧率
videoGOP 当前视频 GOP,也就是每两个关键帧(I帧)间隔时长,单位 s
netSpeed 当前的发送/接收速度
netJitter 网络抖动情况,抖动越大,网络越不稳定
netQualityLevel 网络质量:0:未定义 1:最好 2:好 3:一般 4:差 5:很差 6:不可用
videoWidth 视频画面的宽度
videoHeight 视频画面的高度
videoCache 主播端堆积的视频帧数
audioCache 主播端堆积的音频帧数

示例代码

在开发者工具中预览效果

  <live-pusher url="https://domain/push_stream" mode="RTC" autopush bindstatechange="statechange" style="width: 300px; height: 225px;" />
Page({
  statechange(e) {
    console.log('live-pusher code:', e.detail.code)
  }
})

标签:1.7,false,string,pusher,number,live,boolean,推流
From: https://www.cnblogs.com/AtlasLapetos/p/18626998

相关文章

  • Keepalived的工作原理是什么?
    Keepalived是一个在Linux系统中广泛使用的软件,用于实现高可用性(HighAvailability,HA)和负载均衡。它的核心工作原理基于VirtualRouterRedundancyProtocol(VRRP)协议,旨在避免单点故障,确保关键服务如Web服务器、数据库服务器等的不间断运行。以下是Keepalived工作原理......
  • memcached+keepalived实现主主复制和高可用【转】
    keepalived+memcached主主复制高可用介绍:客户端连接两台服务器之间的VIP地址,如果后端服务器故障自动切换。 Keepalive原理:1.故障检测:Keepalived的作用是检测memcached服务器的状态是否正常。2.主从切换:Keepalived如果检测到memcached服务发生DOWN机或者死机等,能将VIP从主服务......
  • Vue 核心知识:内置组件Keeplive
    让我们一起走向未来......
  • vue 中 keep-alive 详解
    一、定义与作用`keep-alive`是Vue.js提供的一个内置组件,用于缓存动态组件。当一个组件被包裹在`keep-alive`组件内部时,在组件切换过程中,该组件的状态(如组件中的数据、DOM状态等)会被保留,而不是像普通组件那样被销毁和重新创建。这对于提高应用性能和用户体验非常有用,特别是......
  • 【亲测能用】专业音乐制作软件Ableton Live Suite v12.1.5 中文版(附安装教程)
    软件介绍在数字音频工作站(DAW)的领域中,AbletonLive以其创新和灵活性脱颖而出,成为全球音乐家和制作人的首选工具。由德国Ableton公司精心打造,这款软件不仅支持无缝的音乐播放和即时编辑,还提供了强大的音频效果和虚拟乐器,让音乐创作变得无限可能。功能亮点AbletonLive12.1.5版......
  • 开源数字人直播DH_live web整合包免训练使用教程
    资源导航首页项目地址基于开源项目:DH_live做的web交互系统主要实现:免训练数字人视频制作和实时语音数字人可搭配一些直播场控软件的语音驱动数字人进行直播  整合包下载「数字人(可直播用+数字人视频制作)」链接:https://pan.quark.cn/s/2e06a0249917优化内容:......
  • vue-keep-alive的用法
    第一步先在需要保留的组件中添加name属性第二步添加keep-alive这样浏览器会报一个警告建议我们使用插槽方式......
  • 解决系统提示windowslivelogin.dll找不到丢失问题
    在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包文件不完整造成,原因可能是某些系统防护软件将重要的DLL文件识别为可疑,阻止并放入了隔离单里,还有一些常见的DLL文件缺少是因为系统没有安装齐全的微软运行库,还有部分情况是因为......
  • keepalived的高可用集群
    keepalived的概念keepalived的工作原理基于vrrp实现的调度器高可用方案keepalived的配置实验先在调度服务器上安装keepalived和ipvsadmapt-yinstallkeepalivedipvsadm复制keepalived的配置文件到/etc/keepalived/目录下cp/usr/share/doc/keepalived/samples......
  • [Tools] Automate Creating a Local React Project, GitHub Repository, and Live Hos
    It'sfairlytrivialtocreateaReactproject,butthere'salwaysabighurdlebetweencreatingitlocallyandmakingitshareablesothatsomeoneelsecanrunit.ThislessonwalksyouthroughtheprocessofautomatingcreatingaReactproject......