微信小程序媒体组件是微信小程序开发中的一个重要组件,它可以帮助开发者更好地实现多媒体内容的展示。微信小程序媒体组件包括图片、视频、音频、文本、图文混排五大部分,其中图片是最常用的媒体组件,它可以帮助开发者快速地将图片内容显示出来。
视频是微信小程序中也十分重要的一个媒体组件,它可以帮助开发者将视频内容显示出来,并支持视频的暂停、快进、快退、重新播放功能。此外,还有一些其他的功能,如视频截图、视频旋转、视频剪切、视频水印等。
而对于音频来说,微信小程序也有相应的媒体组件支持。开发者可以使用该媒体组件来显示各式各样的声音效果,并支持声音的暂停、快进、快退功能。此外,还有一些其他的功能,如声波录制、声波剪切、声波水印。
文本也是微信小程序中重要的一个媒体内容之一,开发者可以使用该文本内容来显示各式各样的文字效果,并支持文字样式的设定。此外,还有一些其他的功能,如字体大小设定、字体样式设定、表情包使用。
最后是图文混排这个重要的媒体内容之一。该内容不光包含了图片或者文字内容,而且还包含了其他多媒体内容如视频或者声波录制之中去。使用该图文混排内容无形之中会将所有多媒体内容都整合在一个留中去呈现出来。
基础库 1.7.0 开始支持,低版本需做兼容处理。
实时音视频播放(v2.9.1 起支持同层渲染)。
暂只针对国内主体如下类目的小程序开放,需要先通过类目审核,再在小程序管理后台,「开发」-「接口设置」中自助开通该组件权限。
一级类目/主体类型 | 二级类目 | 小程序内容场景 |
---|---|---|
社交 | 直播 | 涉及娱乐性质,如明星直播、生活趣事直播、宠物直播等。选择该类目后首次提交代码审核,需经当地互联网主管机关审核确认,预计审核时长 7 天左右 |
教育 | 在线视频课程 | 网课、在线培训、讲座等教育类直播 |
医疗 | 互联网医院,公立医疗机构,私立医疗机构 | 问诊、大型健康讲座等直播 |
金融 | 银行、信托、公募基金、私募基金、证券/期货、证券、期货投资咨询、保险、征信业务、新三板信息服务平台、股票信息服务平台(港股/美股)、消费金融 | 金融产品视频客服理赔、金融产品推广直播等 |
汽车 | 汽车预售服务 | 汽车预售、推广直播 |
政府主体帐号 | / | 政府相关工作推广直播、领导讲话直播等 |
工具 | 视频客服 | 不涉及以上几类内容的一对一视频客服服务,如企业售后一对一视频服务等 |
IT科技 | 多方通信 | 为多方提供电话会议/视频会议等服务 |
属性 | 类型 | 默认值 | 必填 | 说明 | 最低版本 |
---|---|---|---|---|---|
src | string | 否 | 音视频地址。目前仅支持 flv , rtmp 格式 |
1.7.0 | |
mode | string | live | 否 | 模式 | 1.7.0 |
autoplay | boolean | false | 否 | 自动播放 | 1.7.0 |
muted | boolean | false | 否 | 是否静音 | 1.7.0 |
orientation | string | vertical | 否 | 画面方向 | 1.7.0 |
object-fit | string | contain | 否 | 填充模式,可选值有 contain ,fillCrop
|
1.7.0 |
background-mute | boolean | false | 否 | 进入后台时是否静音(已废弃,默认退后台静音) | 1.7.0 |
min-cache | number | 1 | 否 | 最小缓冲区,单位s(RTC 模式推荐 0.2s) | 1.7.0 |
max-cache | number | 3 | 否 | 最大缓冲区,单位s(RTC 模式推荐 0.8s)。缓冲区用来抵抗网络波动,缓冲数据越多,网络抗性越好,但时延越大。 | 1.7.0 |
sound-mode | string | speaker | 否 | 声音输出方式 | 1.9.90 |
auto-pause-if-navigate | boolean | true | 否 | 当跳转到本小程序的其他页面时,是否自动暂停本页面的实时音视频播放 | 2.5.0 |
auto-pause-if-open-native | boolean | true | 否 | 当跳转到其它微信原生页面时,是否自动暂停本页面的实时音视频播放 | 2.5.0 |
picture-in-picture-mode | string/Array | 否 | 设置小窗模式: push, pop,空字符串或通过数组形式设置多种模式(如: ["push", "pop"]) | 2.10.3 | |
bindstatechange | eventhandle | 否 | 播放状态变化事件,detail = {code} | 1.7.0 | |
bindfullscreenchange | eventhandle | 否 | 全屏变化事件,detail = {direction, fullScreen} | 1.7.0 | |
bindnetstatus | eventhandle | 否 | 网络状态通知,detail = {info} | 1.9.0 | |
bindaudiovolumenotify | eventhandler | 否 | 播放音量大小通知,detail = {} | 2.10.0 | |
bindenterpictureinpicture | eventhandler | 否 | 播放器进入小窗 | 2.11.0 | |
bindleavepictureinpicture | eventhandler | 否 | 播放器退出小窗 | 2.11.0 |
mode 的合法值
值 | 说明 | 最低版本 |
---|---|---|
live | 直播 | |
RTC | 实时通话,该模式时延更低 |
orientation 的合法值
值 | 说明 | 最低版本 |
---|---|---|
vertical | 竖直 | |
horizontal | 水平 |
object-fit 的合法值
值 | 说明 | 最低版本 |
---|---|---|
contain | 图像长边填满屏幕,短边区域会被填充⿊⾊ | |
fillCrop | 图像铺满屏幕,超出显示区域的部分将被截掉 |
sound-mode 的合法值
值 | 说明 | 最低版本 |
---|---|---|
speaker | 扬声器 | |
ear | 听筒 |
picture-in-picture-mode 的合法值
值 | 说明 | 最低版本 |
---|---|---|
[] | 取消小窗 | |
push | 路由 push 时触发小窗 | |
pop | 路由 pop 时触发小窗 |
代码 | 说明 |
---|---|
2001 | 已经连接服务器 |
2002 | 已经连接 RTMP 服务器,开始拉流 |
2003 | 网络接收到首个视频数据包(IDR) |
2004 | 视频播放开始 |
2005 | 视频播放进度 |
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 | 网络抖动情况,为 0 时表示没有任何抖动,值越大表明网络抖动越大,网络越不稳定 |
videoWidth | 视频画面的宽度 |
videoHeight | 视频画面的高度 |
live-player 小窗支持以下三种触发模式(在组件上设置 picture-in-picture-mode 属性):
此外,小窗还支持以下特性:
当播放器进入小窗模式后,播放器所在页面处于 hide 状态(触发 onHide 生命周期),该页面不会被销毁。当小窗被关闭时,播放器所在页面会被 unload (触发 onUnload 生命周期)。
<live-player src="https://domain/pull_stream" rel="external nofollow" mode="RTC" autoplay bindstatechange="statechange" binderror="error" style="width: 300px; height: 225px;" />
Page({
statechange(e) {
console.log("live-player code:", e.detail.code)
},
error(e) {
console.error("live-player error:", e.detail.errMsg)
}
})
ad-custom基础库 2.10.4 开始支持,低版本需做兼容处理。原生模板 广告。属性类型默认值必填说明最低版本unit-idstring是广告单...
UDPSocketwx.createUDPSocket()基础库 2.7.0 开始支持,低版本需做兼容处理。创建一个 UDP Socket 实例。使用前请注意阅读相关说...
关键词:状态机,售卖机有限状态机(Finite-StateMachine,FSM),简称状态机,是表示有限个状态以及在这些状态之间的转移和动作...
在本节中,我们将学习如何使用不同的传感器连接我们的Arduino板。我们将讨论以下传感器: 湿度传感器(DHT22)温度传感器(LM35...
desktopCapturer模块可用来获取可用资源,这个资源可通过getUserMedia捕获得到.// 在渲染进程中.var desktopCapturer = require(...
设备模式移动仿真随着移动用户的增长,移动端友好的响应式网站设计变得越来越重要。网页的内容要在不同的设备以及各种网络环境下...
凹凸图用于使用Measure值之一来比较两个尺寸。它们对于探索时间维度或地方维度或与分析相关的其他维度的值的变化非常有用。凹凸...
项目脚手架grunt-initgrunt-init是一个用于自动创建项目脚手架的工具。它会基于当前工作环境和你给出的一些配置选项构建一个完整...
grunt.optionGrunt的option API被用来在多个任务之间共享参数、访问命令行中设置的参数。一个简单的案例就是为一个目标(target...
介绍WipeLeft类定义了一个擦除左效果。 组件的前或后状态必须是不可见的。类声明以下是 mx.effects.WipeLeft 类的声明:public cl...