播放器 API 参考
更新时间: 2024/08/07 10:36:47
如果您是第一次使用neplayer,请先阅读 开发指南。
Constructor
neplayer( idString, [options], [ready]);
Parameters
name | type | required | description |
---|---|---|---|
idString | String | yes | video标签的 ID 属性值 |
options | Object | no | 初始化参数对象,详情见下 |
ready | Function | no | 播放器初始化完成时的回调函数 |
@params options
{
"enableDecodeH265": false, //是否启用H265解码,默认false
"canvasId": "canvas", //canvas标签的ID值,H265播放使用
"decoderPath": "https://xxx", //H265解码库地址
"controls": true, //是否显示控制条
"autoplay": true, //是否自动播放(ios不支持自动播放)
/*预加载选项*/
"preload": "auto",
/*
'auto'预加载视频(需要浏览器允许);
'metadata'仅预加载视频meta信息;
'none'不预加载;
*/
"poster": "myPoster.jpg", //视频播放前显示的图片
"loop": true, //是否循环播放
"width": 640, //设置播放器宽度
"height": 480, //设置播放器高度
"techOrder": ['html5','flvjs','flash'], //优先使用的播放模式(2.3.0版本开始支持flvjs)
"streamTimeoutTime": 30 * 1000, //拉流超时时间,默认30s
/*设置播放器控件*/
controlBar: {
playToggle: false
}
/*
//设置不显示大播放按钮
bigPlayButton:false,
*/
/*默认播放器控件列表
posterImage
textTrackDisplay
loadingSpinner
bigPlayButton
controlBar
playToggle
volumeMenuButton
currentTimeDisplay
timeDivider
durationDisplay
progressControl
seekBar
loadProgressBar
mouseTimeDisplay
playProgressBar
liveDisplay
remainingTimeDisplay
customControlSpacer
playbackRateMenuButton
chaptersButton
descriptionsButton
subtitlesButton
captionsButton
audioTrackButton
fullscreenToggle
*/
}
关于播放器控件的介绍以及如何自定义播放器样式和控件的说明,请参见 自定义控件。
Methods
请在播放器初始化完成后再调用 API 接口,推荐使用播放器的初始化完成回调函数。
getCurrentPosition()
获取当前播放位置(单位毫秒)
var currentPos = myPlayer.getCurrentPosition();
getDuration()
获取视频总时长(单位毫秒)
var duration = myPlayer.getDuration();
getPlayableDuration()
获取当前已缓存位置的时间点(单位毫秒)
var buffered = myPlayer.getPlayableDuration();
getVersion()
获取sdk版本号
var version = myPlayer.getVersion();
getVideoHeight()
获取视频高度
var height = myPlayer.getVideoHeight();
getVideoWidth()
获取视频宽度
var width = myPlayer.getVideoWidth();
play()
开始播放
myPlayer.play();
pause()
暂停播放
myPlayer.pause();
reset()
重置播放器
myPlayer.reset();
release()
释放播放器所有资源
myPlayer.release();
seekTo(sec)
设置到指定时间点播放
Parameters
name | type | required | description |
---|---|---|---|
sec | Number | yes | 要跳转到的播放时间(单位秒) |
myPlayer.seekTo(12345);
setDataSource(source)
设置数据源
Parameters
name | type | required | description |
---|---|---|---|
source | String ¦ Object ¦ Array | yes | 要设置的数据源 |
数据源支持三种格式:
- URL字符串(不推荐)
请确保当前播放器模式(HTML5/Flash)支持这个url提供的视频,否则请使用数据源对象格式
myPlayer.setDataSource("http://www.example.com/path/to/video.mp4");
- 数据源对象
播放器会根据提供的视频格式自动切换播放模式(HTML5/Flash)
myPlayer.setDataSource({
type: "video/mp4",
src: "http://www.example.com/path/to/video.mp4"
});
- 直播
直播场景中,使用flv拉流时,可以设置本地延迟
myPlayer.setDataSource({
type: "video/x-flv",
src: "http://www.example.com/path/to/video.flv",
flvConf: {
liveDelayMaxDuration: 3 //flv播放延迟,默认3s, isLive为true时生效
},
isLive: true
});
- 包含多个不同视频格式数据源对象的数组
播放器会依次尝试,最终找到支持的格式进行播放
myPlayer.setDataSource([
{type: "video/mp4",src: "http://www.example.com/path/to/video.mp4"},
{type: "video/x-flv",src: "http://www.example.com/path/to/video.flv"},
{type: "application/x-mpegURL",src: "http://www.example.com/path/to/video.hls"}
]);
如果要在播放器初始化完成后立即调用,必须将 setDataSource
写在播放器初始化完成时的回调函数中。
如果要播放点播flv加密视频,需要提供额外的解密相关信息
// 播放点播flv加密视频,需要增加字段decryptInfo
// decryptInfo字段值是一个对象,包含了transferToken, accid, token, appKey等信息
// 这些信息需要用户通过自己的应用服务器获取
var option = {
"type": "video/x-flv",
"src": "http://domain.vod.xxx/path/to/some.flv",
"decryptInfo" : {
"transferToken":"tag=xxx&time=xxx&expire=xxx&nonce=xxx&algo=1&checksum=xxx",
"accid": "xxx",
"token": "xxx",
"appKey": "xxx"
}
}
myPlayer.setDataSource(option);
setMute(mute)
设置是否静音,如果没有参数,则返回当前静音状态(true/false)
name | type | required | description |
---|---|---|---|
mute | Boolean | no | 是否静音 |
myPlayer.setMute(true)
setVolume(volume)
设置音量 参数说明如下表所示。
name | type | required | description |
---|---|---|---|
volume | Number | yes | 要设置的音量。取值范围:
|
myPlayer.setVolume(0.5);
getVolume()
获取当前音量(0 ~ 1)
var volume = myPlayer.getVolume();
resize( width, height)
设置播放器宽高
Parameters
name | type | required | description |
---|---|---|---|
width | Number | yes | 要设置的宽度 |
height | Number | yes | 要设置的高度 |
myPlayer.resize( 640, 480);
enterFullscreen()
全屏播放
myPlayer.enterFullscreen();
isFullscreen()
是否在全屏播放
var result = myPlayer.isFullscreen()
exitFullscreen()
退出全屏
myPlayer.exitFullscreen();
getPlayState()
获取播放状态
- 1:播放中
- 2:暂停中
- 3:播放结束
var playState = myPlayer.getPlayState();
onPlayState( stateCode, [func])
注册播放状态回调函数
Parameters
name | type | required | description |
---|---|---|---|
stateCode | Number | yes | 要注册的播放状态 (1:播放中;2:暂停中;3:播放结束) |
func | function | yes | 要注册的回调函数 |
myPlayer.onPlayState(1,function(){
console.log('play');
});
myPlayer.onPlayState(2,function(){
console.log('pause');
});
myPlayer.onPlayState(3,function(){
console.log('ended');
});
refresh()
重新拉流并播放
myPlayer.refresh();
setLiveDelayMaxDuration()
修改直播延迟时间,目前仅支持flv拉流,单位 秒
myPlayer.setLiveDelayMaxDuration(duration);
on()
监听播放相关的事件。 具体支持的事件如下:
type | description |
---|---|
loadedmetadata | 元数据加载的事件。当指定的音频或视频的元数据已加载时触发,元数据包括:时长、尺寸(仅视频)以及文本轨道 |
loadeddata | 视频下载监听的事件。当当前帧的数据已加载,但没有足够的数据来播放指定音频/视频的下一帧时触发 |
canplay | 可播放的事件。当浏览器能够开始播放指定的音频或视频时触发 |
canplaythrough | 可流畅播放的事件。当浏览器预计能够在不停下来进行缓冲的情况下,持续播放指定的音频或视频时触发 |
play | 播放是触发该事件 |
pause | 暂停时触发该事件 |
playing | 当视频因缓冲而暂停或停止后,已就绪时触发该事件 |
ended | 播放结束时触发该事件 |
myPlayer.on("playing",function(){
console.log("playing");
})
off()
解除事件监听
onError([func])
注册错误回调函数
Parameters
name | type | required | description |
---|---|---|---|
func | function | yes | 要注册的回调函数 |
/*
播放器在调用错误回调函数时,会向回调函数传递一个错误对象参数
{
errCode: //错误代码
errMsg: //错误信息
}
*/
myPlayer.onError(function(err){
console.log(err.errCode);
console.log(err.errMsg);
});
错误码
errCode | errMsg |
---|---|
1 | You aborted the media playback |
2 | A network error caused the media download to fail part-way. |
3 | The media playback was aborted due to a corruption…media used features your browser did not support. |
4 | The media could not be loaded, either because the server or network failed or because the format is not supported. |
5 | The media is encrypted and we do not have the keys to decrypt it. |
6 | 请勿使用推流地址拉流 |
7 | 拉流超时 |
此文档是否对你有帮助?