播放器 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 要设置的音量。取值范围:
  • 普通拉流场景中,取值范围是0 ~ 1
  • NERTC 低延时直播协议拉流场景中,取值范围是0 ~ 100
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 拉流超时
此文档是否对你有帮助?
有帮助
去反馈
  • Constructor
  • Parameters
  • Methods
  • getCurrentPosition()
  • getDuration()
  • getPlayableDuration()
  • getVersion()
  • getVideoHeight()
  • getVideoWidth()
  • play()
  • pause()
  • reset()
  • release()
  • seekTo(sec)
  • Parameters
  • setDataSource(source)
  • Parameters
  • setMute(mute)
  • setVolume(volume)
  • getVolume()
  • resize( width, height)
  • Parameters
  • enterFullscreen()
  • isFullscreen()
  • exitFullscreen()
  • getPlayState()
  • onPlayState( stateCode, [func])
  • Parameters
  • refresh()
  • setLiveDelayMaxDuration()
  • on()
  • off()
  • onError([func])
  • Parameters
  • 错误码