这是开源版
的API文档,这是开源版
的API文档,这是开源版
的API文档(三遍),PRO的API文档
请联系作者。
options 支持的参数有:
- 类型:
DOM
orstring
- 用法:
播放器容器。
若为 string ,则底层调用的是 document.querySelector(container)
源码
let $container = options.container;
if (typeof options.container === 'string') {
$container = document.querySelector(options.container);
}
if (!$container) {
throw new Error('Jessibuca need container option');
return;
}
不建议业务层在container参数上面有额外的css属性样式,尤其是缩放,旋转之类的,这样会导致播放器内部的画面不正常。
可以通过在业务层的div
下面再放一个div
作为播放器容器,这样可以规避掉一些问题。
<div id="your-container">
<div id="player-container"></div>
</div>
new Jessibuca({
container: '#player-container'
})
- 类型:
number
- 默认值:
1
- 用法: 设置缓冲时长,
单位秒
。
- 类型:
string
- 默认值:
decoder.js
- 用法:
worker地址
默认引用的是根目录下面的decoder.js文件 ,decoder.js 与 decoder.wasm文件必须是放在同一个目录下面。
例如vue项目中,jessibuca.js
文件在public/jessibuca/jessibuca.js
(decoder.js也在同级目录下)。
需要配置的 decoder
参数是: decoder: '/jessibuca/decoder.js'
如果配置的参数是相对地址,是针对于http地址上面的相对地址。
例如当前页面的是 http://test.com/a/b/c.html
如果new 播放器的时候配置的 decoder
的参数是相对地址'./decoder.js',则会去请求 http://test.com/a/b/decoder.js
- 类型:
boolean
- 默认值:true
- 用法:
是否不使用离屏模式(提升渲染能力)
该特性是实验性特性,某些版本的浏览器会出现内存无缘无故变大的情况。谨慎使用。
由于目前浏览器兼容性太差,会出现慕名奇妙的错误问题,目前播放器内部禁用离屏渲染。
hiddenAutoPause
- 类型:
boolean
- 默认值:false
- 用法:
见
是否开启当页面的'visibilityState'变为'hidden'的时候,自动暂停播放。
- 类型:
boolean
- 默认值:true
- 用法:
是否有音频,如果设置false
,则不对音频数据解码,提升性能。
- 类型:
number
- 默认值:0
- 用法:
设置旋转角度,只支持,0(默认) ,180,270 三个值。
- 类型:
boolean
- 默认值:
true
- 用法:
- 当为
true
的时候:视频画面做等比缩放后,高或宽对齐canvas区域,画面不被拉伸,但有黑边。 等同于setScaleMode(1)
- 当为
false
的时候:视频画面完全填充canvas区域,画面会被拉伸。等同于setScaleMode(0)
video标签(useMSE,useWCS+wcsUseVideoRender)渲染的页面暂不支持这个属性。
- 类型:
boolean
- 默认值:
false
- 用法:
- 当为
true
的时候:视频画面做等比缩放后,完全填充canvas区域,画面不被拉伸,没有黑边,但画面显示不全。等同于setScaleMode(2)
video标签(useMSE,useWCS+wcsUseVideoRender)渲染的页面暂不支持这个属性。
- 类型:
boolean
- 默认值:
false
- 用法:
- 当为
true
的时候:ws协议不检验是否以.flv为依据,进行协议解析。
- 类型:
boolean
- 默认值:
false
- 用法: 是否开启控制台调试打印
- 类型:
number
- 默认值:
10
- 用法:
- 设置超时时长, 单位秒
- 在连接成功之前(
loading
)和播放中途(heart
),如果超过设定时长无数据返回,则回调timeout事件
- 类型:
number
- 默认值:
5
- 用法:
- 设置超时时长, 单位秒
- 播放中途,如果超过设定时长无数据返回,则回调timeout事件
- 类型:
boolean
- 默认值:
true
- 用法: 是否开启心跳超时之后自动再播放
heartTimeout 心跳超时之后自动再播放,不再抛出异常,而直接重新播放视频地址。
只会在播放地址是正常能够访问通的情况下,才会重新播放。像http 404,500等错误,不会重新播放。ws连接失败也不会重新播放。 这种会走到异常事件。
- 类型:
number
- 默认值:
3
- 用法: heartTimeoutReplay 重试次数
heartTimeoutReplay 重试失败之后,不再重新播放视频地址。
是整个生命周期中重试的次数。
如果想无限次重试,可以设置为-1
- 类型:
number
- 默认值:
10
- 用法:
- 设置超时时长, 单位秒
- 在连接成功之前,如果超过设定时长无数据返回,则回调timeout事件
- 类型:
boolean
- 默认值:
true
- 用法: 是否开启loading超时之后自动再播放
loadingTimeout 心跳超时之后自动再播放,不再抛出异常,而直接重新播放视频地址。
只会在播放地址是正常能够访问通的情况下,才会重新播放。像http 404,500等错误,不会重新播放。ws连接失败也不会重新播放。 这种会走到异常事件,。
- 类型:
number
- 默认值:
3
- 用法: loadingTimeoutReplay 重试次数
loadingTimeoutReplay 重试失败之后,不再重新播放视频地址。
如果想无限次重试,可以设置为-1
- 类型:
boolean
- 默认值:
false
- 用法: 是否支持屏幕的双击事件,触发全屏,取消全屏事件。
点击底部的 controls UI条(里面元素)不会触发全屏事件。
- 类型:
boolean
- 默认值:
false
- 用法: 是否显示网速
- 类型:
object
- 默认值:
{ fullscreen:false, screenshot: false, play: false, audio: false, record:false }
- 用法: 配置操作按钮 其中
- fullscreen 是否显示全屏按钮
- screenshot 是否显示截图按钮
- play 是否显示播放暂停按钮
- audio 是否显示声音按钮
- record 是否显示录制按钮
- 类型:
boolean
- 默认值:
false
- 用法: 开启屏幕常亮,在手机浏览器上, canvas标签渲染视频并不会像video标签那样保持屏幕常亮。
PC端不会生效,仅手机端生效
- 类型:
boolean
- 默认值:
false
- 用法: 是否开启声音,默认是关闭声音播放的。
必须通过按钮或者点击事件触发play() 方法,才会播放出声音来,不然还是静音的。 浏览器不允许自动播放的视频自动播放声音。
- 类型:
string
- 默认值:``
- 用法: 加载过程中文案。
- 类型:
string
- 默认值:``
- 用法: 背景图片。
- 类型:
boolean
- 默认值:
false
- 用法: 是否开启MediaSource硬解码
视频编码只支持H.264视频(Safari on iOS不支持)
> 不支持 forceNoOffscreen 为 false (开启离屏渲染)
优先级高于useWCS:true
- 类型:
boolean
- 默认值:
false
- 用法: 是否开启Webcodecs硬解码
视频编码只支持H.264视频 (需在chrome 94版本以上,需要https或者localhost环境)
> 支持 forceNoOffscreen 为 false (开启离屏渲染)
如果同时设置了useMSE:true, 则优先使用useMSE
- 类型:
boolean
- 默认值:
true
- 用法: webcodecs硬解码是否通过video标签渲染
> forceNoOffscreen 设置为false之后(通过OffscreenCanvas渲染之),wcsUseVideoRender不会生效。
webcodecs硬解码之后,默认是通过canvas 渲染出来的,可以通过配置通过video标签渲染,提升渲染性能。
现在默认 video标签渲染,提升渲染性能。
- 类型:
boolean
- 默认值:
true
- 用法: 在使用MSE或者Webcodecs 播放H265的时候,是否自动降级到wasm模式。
设置为false 则直接关闭播放,抛出Error 异常,设置为true 则会自动切换成wasm模式播放。
- 类型:
boolean
- 默认值:
false
- 用法: 是否开启键盘快捷键
目前支持的键盘快捷键有:esc -> 退出全屏;arrowUp -> 声音增加;arrowDown -> 声音减少;
- 类型:
boolean
- 默认值:
true
- 用法: 是否开启解码失败重新播放
wasm解码报错之后,不再抛出异常,而是直接重新播放视频地址。
- 类型:
boolean
- 默认值:
false
- 用法: 底部控制台是否自动隐藏
只有鼠标聚焦到播放器内部才会显示,移除之后,会消失。
- 类型:
string
- 默认值:
webm
- 用法: 默认录制的视频格式
支持
webm
,mp4
参数
- 类型:
boolean
- 默认值:
false
- 用法:是否使用web全屏(旋转90度)(只会在移动端生效)。
如果手机设置了自动选择,建议不要开启。
web全屏使用的是css方式实现的伪全屏,实现的是横屏播放的。如果手机设置了自动旋转,建议不要使用这个功能。
ios上面不支持系统级别的全屏方法,推荐使用这个参数。
- 类型:
boolean
- 默认值:
true
- 用法:是否自动使用系统全屏
如果设置了true,播放器会检查是否支持系统提供的全屏API,如果支持,就会优先使用系统全屏API,否则使用web全屏API(useWebFullScreen)
。
- 参数:
{boolean} flag
- 用法: 是否开启控制台调试打印
// 开启
jessibuca.setDebug(true)
// 关闭
jessibuca.setDebug(false)
- 用法: 静音
jessibuca.mute()
- 用法: 取消静音
jessibuca.cancelMute()
iPhone,chrome等要求自动播放时,音频必须静音,需要由一个真实的用户交互操作来恢复,不能使用代码。
- 用法: 留给上层用户操作来触发音频恢复的方法。
iPhone,chrome等要求自动播放时,音频必须静音,需要由一个真实的用户交互操作来恢复,不能使用代码。
https://developers.google.com/web/updates/2017/09/autoplay-policy-changes
- 参数:
{number} time
- 用法:
设置超时时长, 单位秒 在连接成功之前和播放中途,如果超过设定时长无数据返回,则回调timeout事件
jessibuca.setTimeout(10)
jessibuca.on('timeout', function () {
//
});
-
参数:
{number} mode
-
用法:
0
视频画面完全填充canvas区域,画面会被拉伸 等同于参数isResize
为false1
视频画面做等比缩放后,高或宽对齐canvas区域,画面不被拉伸,但有黑边 等同于参数isResize
为true2
视频画面做等比缩放后,完全填充canvas区域,画面不被拉伸,没有黑边,但画面显示不全 等同于参数isFullResize
为true
video标签(useMSE,useWCS+wcsUseVideoRender)渲染的页面暂不支持这个方法。
jessibuca.setScaleMode(0)
jessibuca.setScaleMode(1)
jessibuca.setScaleMode(2)
- 返回:
{Promise}
- 用法: 暂停播放
jessibuca.pause().then(() => {
console.log('pause success')
jessibuca.play().then(() => {
}).catch((e) => {
})
}).catch((e) => {
console.log('pause error', e);
})
可以在pause 之后,再调用 play()
方法就继续播放之前的流。
- 用法: 关闭视频,不释放底层资源
- 返回:
{Promise}
废弃,推荐使用destroy()方法
内部就是调用的destroy()方法
jessibuca.close().then(() => {
console.log('close success')
}).catch((e) => {
console.log('close error', e);
});
- 用法: 关闭视频,释放底层资源
- 返回:
{Promise}
jessibuca.destroy().then(()=>{
// todo: next
})
// 或者
await jessibuca.destroy();
- 用法: 清理画布为黑色背景
jessibuca.clearView()
video标签(useMSE,useWCS+wcsUseVideoRender)渲染的页面暂不支持这个方法。
-
参数:
{string} url
url 地址{object} options
额外参数{object} headers
http 请求头
-
返回:
{Promise}
-
用法: 播放视频
jessibuca.play('url').then(() => {
console.log('play success')
}).catch((e) => {
console.log('play error', e)
})
// http 授权认证。
jessibuca.play('url',{headers:{'Authorization':'test111'}}).then(() => {
console.log('play success')
}).catch((e) => {
console.log('play error', e)
})
//
jessibuca.play()
- 用法: 重新调整视图大小
-
参数:
{number} time
-
用法: 设置最大缓冲时长,单位秒,播放器会自动消除延迟。
等同于 videoBuffer
参数。
// 设置 200ms 缓冲
jessibuca.setBufferTime(0.2)
- 参数:
{number} deg
- 用法: 设置旋转角度,支持,0(默认), 90, 180, 270 四个值。
可用于实现监控画面小窗和全屏效果,由于iOS没有全屏API,此方法可以模拟页面内全屏效果而且多端效果一致。
注意,当旋转90度后,用户也会旋转手机,这时如果手机未锁定方向,画面又可能因为浏览器旋转导致画面又旋转了。可以监听页面旋转事件,将角度又旋转回0
jessibuca.setRotate(0)
jessibuca.setRotate(90)
jessibuca.setRotate(180)
jessibuca.setRotate(270)
-
参数:
{number} volume
-
用法:
- 设置音量大小,取值0 — 1
- 当为0时,完全无声
- 当为1时,最大音量,默认值
区别于 mute 和 cancelMute 方法,虽然设置setVolume(0) 也能达到 mute方法,但是mute 方法是不调用底层播放音频的,能提高性能。而setVolume(0)只是把声音设置为0 ,以达到效果。
jessibuca.setVolume(0.2)
jessibuca.setVolume(0)
jessibuca.setVolume(1)
- 返回值:
boolean
- 用法: 返回是否加载完毕
仅为兼容老的2.x语法,3.x版本不需要这个事件。
var result = jessibuca.hasLoaded()
console.log(result) // true
- 用法: 开启屏幕常亮,在手机浏览器上, canvas标签渲染视频并不会像video标签那样保持屏幕常亮。 H5目前在chrome\edge 84, android chrome 84及以上有原生亮屏API, 需要是https页面 其余平台为模拟实现,此时为兼容实现,并不保证所有浏览器都支持
jessibuca.setKeepScreenOn()
-
参数:
{boolean} flag
-
用法: 全屏(取消全屏)播放视频
iOS不支持,iPadOS13后支持
推荐iOS端配置上 useWebFullScreen 这个参数。
jessibuca.setFullscreen(true)
//
jessibuca.setFullscreen(false)
- 参数:
{string} filename
{string} format
{number} quality
{string} type
- 用法:
截图,调用后弹出下载框保存截图
- filename: 可选参数, 保存的文件名, 默认
时间戳
- format : 可选参数, 截图的格式,可选png或jpeg或者webp ,默认
png
- quality: 可选参数, 当格式是jpeg或者webp时,压缩质量,取值0 ~ 1 ,默认
0.92
- type: 可选参数, 可选download或者base64或者blob,默认
download
jessibuca.screenshot("test", "png", 0.5)
const base64 = jessibuca.screenshot("test", "png", 0.5, 'base64')
const fileBlob = jessibuca.screenshot("test", 'blob')
-
参数:
{string} filename
{string} fileType
-
用法: 开始录制。
- fileName: 可选,默认时间戳
- fileType: 可选,默认webm,支持webm 和mp4 格式
jessibuca.startRecord('xxx', 'webm')
- 用法: 暂停录制并下载。
jessibuca.stopRecordAndSave()
- 返回值:
boolean
- 用法: 返回是否正在播放中状态。
var result = jessibuca.isPlaying()
console.log(result) // true
- 返回值:
boolean
- 用法: 返回是否静音。
var result = jessibuca.isMute()
console.log(result) // true
- 返回值:
boolean
- 用法: 返回是否正在录制。
var result = jessibuca.isRecording()
console.log(result) // true
- 用法: 切换底部控制条 隐藏/显示
- 参数:
{boolean} isShow
是否显示
// 显示
jessibuca.toggleControlBar(true)
// 隐藏
jessibuca.toggleControlBar(false)
// 切换 隐藏/显示
jessibuca.toggleControlBar()
- 用法: 获取底部控制条是否显示
- 返回:
{boolean}
const isShow = jessibuca.getControlBarShow()
- 参数:
{string} event
{function} callback
- 用法: 监听方法
jessibuca.on("load", function () {
console.log('load')
})
监听 jessibuca 初始化事件。
仅为兼容老的2.x语法,3.x版本不需要这个事件。
这个事件需要结合loaded属性一起使用。
3.x版本不需要这个事件。可以直接写play()方法。
jessibuca.on("load", function () {
console.log('load')
})
推荐写法
if(jessibuca.loaded){
console.log('load')
}
else {
jessibuca.on("load", function () {
console.log('load')
})
}
当前视频帧pts,单位毫秒ms
jessibuca.on('timeUpdate', function (ts) {
console.log('timeUpdate', ts);
})
当解析出视频信息时回调,2个回调参数
- width:视频宽
- height:视频高
- encTypeCode 视频编码类型(10:h264,12:h265)
- encType 视频编码类型(字符串)
jessibuca.on("videoInfo", function (data) {
console.log('width:', data.width, 'height:', data.width)
})
当解析出音频信息时回调,2个回调参数
- numOfChannels:声频通道
- sampleRate 采样率
- encTypeCode 音频编码类型(10:aac,7:ALAW(g711a),8:MULAW(g711u))
- encType 音频编码类型(字符串)
jessibuca.on("audioInfo", function (data) {
console.log('numOfChannels:', data.numOfChannels, 'sampleRate', data.sampleRate)
})
信息,包含错误信息
jessibuca.on("log", function (data) {
console.log('data:', data)
})
错误信息
目前已有的错误信息:
- jessibuca.ERROR.playError ;播放错误,url 为空的时候,调用play方法
- jessibuca.ERROR.fetchError ;http 请求失败
- jessibuca.ERROR.websocketError; websocket 请求失败
- jessibuca.ERROR.webcodecsH265NotSupport; webcodecs 解码 h265 失败
- jessibuca.ERROR.mediaSourceH265NotSupport; mediaSource 解码 h265 失败
- jessibuca.ERROR.wasmDecodeError ; wasm 解码失败
jessibuca.on("error", function (error) {
if (error === jessibuca.ERROR.fetchError) {
//
} else if (error === jessibuca.ERROR.webcodecsH265NotSupport) {
//
}
console.log('error:', error)
})
当前网速, 单位KB 每秒1次,
jessibuca.on("kBps", function (data) {
console.log('kBps:', data)
})
渲染开始
如果需要在start 之后调用截图方法,需要写一个延迟方法去执行。因为代码中无法感应到画面被渲染出来了。
jessibuca.on("start", function () {
console.log('start render')
// 如果有截图需求。需要延迟一下,因为代码中无法感应到画面被渲染出来了。
// 1s 之后截图
setTimeout(function () {
jessibuca.screenshot('xxx')
}, 1 * 1000)
})
当设定的超时时间内无数据返回,则回调
- jessibuca.TIMEOUT.loadingTimeout ; 同loadingTimeout
- jessibuca.TIMEOUT.delayTimeout ; 同delayTimeout
jessibuca.on("timeout", function (error) {
console.log('timeout:', error)
})
当play()的时候,如果没有数据返回,则回调
jessibuca.on("loadingTimeout", function () {
console.log('timeout')
})
当播放过程中,如果超过timeout之后没有数据渲染,则抛出异常。
jessibuca.on("delayTimeout", function () {
console.log('timeout')
})
当前是否全屏
jessibuca.on("fullscreen", function (flag) {
console.log('is fullscreen', flag)
})
当前是否web全屏
jessibuca.on("webFullscreen", function (flag) {
console.log('is webFullscreen', flag)
})
触发播放事件
jessibuca.on("play", function (flag) {
console.log('play')
})
触发暂停事件
jessibuca.on("pause", function (flag) {
console.log('pause')
})
触发声音事件,返回boolean值
jessibuca.on("mute", function (flag) {
console.log('is mute', flag)
})
触发音量事件,返回音量值
jessibuca.on("volume", function (volume) {
console.log('volume', volume)
})
流状态统计,流开始播放后回调,每秒1次。
- buf: 当前缓冲区时长,单位毫秒,
- fps: 当前视频帧率,
- abps: 当前音频码率,单位byte,
- vbps: 当前视频码率,单位byte,
- ts:当前视频帧pts,单位毫秒
jessibuca.on("stats", function (s) {
console.log("stats is", s)
})
渲染性能统计,流开始播放后回调,每秒1次。
- 0: 表示卡顿
- 1: 表示流畅
- 2: 表示非常流程
jessibuca.on("performance", function (performance) {
console.log("performance is", performance)
})
录制开始的事件
jessibuca.on("recordStart", function () {
console.log("record start")
})
录制结束的事件
jessibuca.on("recordEnd", function () {
console.log("record end")
})
录制的时候,返回的录制时长,1s一次
jessibuca.on("recordingTimestamp", function (timestamp) {
console.log("recordingTimestamp is", timestamp)
})
监听调用play方法 经过 初始化-> 网络请求-> 解封装 -> 解码 -> 渲染 一系列过程的时间消耗
jessibuca.on("playToRenderTimes", function (times) {
console.log("playToRenderTimes is", times)
})
数据结构如下。
{
playInitStart: '', //1
playStart: '', // 2
streamStart: '', //3
streamResponse: '', // 4
demuxStart: '', // 5
decodeStart: '', // 6
videoStart: '', // 7
playTimestamp: '',// playStart- playInitStart
streamTimestamp: '',// streamStart - playStart
streamResponseTimestamp: '',// streamResponse - streamStart
demuxTimestamp: '', // demuxStart - streamResponse
decodeTimestamp: '', // decodeStart - demuxStart
videoTimestamp: '',// videoStart - decodeStart
allTimestamp: '' // videoStart - playInitStart
}