-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathvideojs.flashls.js
42 lines (33 loc) · 1.63 KB
/
videojs.flashls.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
(function(window, videojs, undefined){
'use strict';
videojs.flashls = function(options){
options = options || {};
// set the swf url to the flashls fork of video-js.swf
// to download the forked swf, go here: https://github.com/mangui/video-js-swf
if(options.swfUrl){
videojs.options.flash.swf = options.swfUrl;
}
videojs.options.flash.flashVars = videojs.options.flash.flashVars || {};
// v0.4.1.1 of mangui/video-js.swf is broken when capleveltostage=true, where it only plays the first level in the
// playlist regardless of the bandwidth it can handle, so we set capleveltostage=false.
// more info can be found here: https://github.com/mangui/flashls/issues/351
videojs.options.flash.flashVars.hls_capleveltostage = false;
// with v0.4.1.1 the seeking would jump pretty far back, so switching the mode to be more accurate versus using
// the closest keyframe
videojs.options.flash.flashVars.hls_seekmode = "ACCURATE";
// we need to set "flash" as a higher priority tech than "html5", so that when
// videojs boots up, it tries to handle the m3u8 source with the flash handler
videojs.options.techOrder = ['flash','html5'];
// register a source handler for m3u8 files, so that videojs knows the flashls' video-js.swf
// can handle playing m3u8 files.
videojs.Flash.registerSourceHandler({
canHandleSource: function(source){
return source.type === 'application/x-mpegURL' ? 'maybe' : '';
},
handleSource: function(source, tech){
tech.setSrc(source.src);
}
});
return videojs;
};
})(window, window.videojs, document);