video.js支持m3u8格式直播






为什么要使用video.js?

1. PC端浏览器并不支持video直接播放m3u8格式的视频

2. 手机端各式各样的浏览器定制的video界面风格不统一,直接写原生的js控制视频兼容性较差

3. video.js解决以上两个问题,还可以有各种视频状态接口暴露,优化体验

 

核心代码:

复制代码



    videojs支持hls直播实例
    



    

    
    
    
    


复制代码

源码请移步github:

videojs支持hls直播实例

https://videojs.github.io/videojs-contrib-hls/#

 

附:

一.  视频状态分析:

复制代码
EVENTS

durationchange
ended
firstplay
fullscreenchange
loadedalldata
loadeddata
loadedmetadata
loadstart
pause
play
progress
seeked
seeking
timeupdate
volumechange
waiting
resize inherited
复制代码

 

currentTime()可以用来发辅助判断视频播放情况

video.js支持m3u8格式直播_第1张图片

 

 


 

二.  视频加载优化:

通过不初始化video无用组件的方式,提高video加载速度

复制代码
var myPlayer = videojs('roomVideo',{
            bigPlayButton : false,
            textTrackDisplay : false,
            posterImage: true,
            errorDisplay : false,
            controlBar : false
        },function(){});
复制代码

未简化之前:

video.js支持m3u8格式直播_第2张图片

简化后:

video.js支持m3u8格式直播_第3张图片

 

 


三.  你可能也会遇到的错误error

错误1:

{code: 4, message: "No compatible source was found for this media."}

解决:去掉video标签的data-setup="{}", 只保留js的初始配置

 

错误2:

video.js Uncaught TypeError: Cannot read property 'one' of undefined

解决:

复制代码
var myPlayer = videojs('roomVideo',{
        bigPlayButton : false,
        textTrackDisplay : false,
        posterImage: false,
        errorDisplay : false,
        controlBar : {
            captionsButton : false,
            chaptersButton: false,
            subtitlesButton:false,
            liveDisplay:false,
            playbackRateMenuButton:false
        }
    },function(){
        console.log(this)
    });
复制代码
复制代码
    var myPlayer = videojs('roomVideo',{
        children : {
            bigPlayButton : false,
            textTrackDisplay : false,
            posterImage: false,
            errorDisplay : false,
            controlBar : {
                captionsButton : false,
                chaptersButton: false,
                subtitlesButton:false,
                liveDisplay:false,
                playbackRateMenuButton:false
            }
        }
    },function(){
        console.log(this)
    });
复制代码

 


你可能感兴趣的:(video.js支持m3u8格式直播)