first thing you need to do to integrate HLS playback into your application is to instanciate an HLS object, that will be used as entry point to interact with flashls.
see example below
import org.mangui.hls.HLS;
import flash.media.Video;
// create instance
var hls : HLS = new HLS();
// setting stage
hls.stage = this.stage;
// creating video (or StageVideo)
video = new Video(640,480);
video.x = 0;
video.y = 0;
video.smoothing = true;
video.attachNetStream(hls.stream);
you can also refer to [Basic] (src/org/mangui/basic/Player.as) or Chromeless players source code to get inspiration and see how to deal with StageVideo for example.
loading is peformed asynchronously. below API should be used
hls.load(url)
flashls will fire below upon completion of manifest loading:
HLSEvent.MANIFEST_PARSED
HLSEvent.MANIFEST_LOADED
see events below
hls.type (VOD/LIVE)
playback control should be performed through a flash.net.NetStream instance, which can be retrieved using hls.stream getter
hls.stream.play(null, -1);
hls.stream.seek(50);
hls.stream.pause();
hls.stream.resume();
...
there are 2 ways to retrieve playback state :
- synchronously, using a getter
hls.playbackState (IDLE/PLAYING/PAUSED/PLAYING_BUFFERING/PAUSED_BUFFERING)
- asynchronously
by monitoring the below event, that will be triggered for every playback state change.
HLSEvent.PLAYBACK_STATE
there are 2 ways to retrieve seek state :
- synchronously, using a getter
hls.seekState (IDLE/SEEKING/SEEKED)
- asynchronously
by monitoring the below event, that will be triggered for every seek state change.
HLSEvent.SEEK_STATE
by default flashls handles quality switch automatically, using heuristics. It is however also possible to manually control quality swith using below API:
return array of available quality levels
get : first level index (index of first level appearing in Manifest. it is usually defined as start level hint for player)
get/set : start level index (level of first fragment that will be played back)
- if not overrided by user : first level appearing in manifest will be used as start level.
- if -1 : automatic start level selection, playback will start from level matching download bandwidth (determined from download of first segment)
default value is firstLevel
get : return quality level used to load first fragment after a seek operation
get : return current playback quality level
set : trigger an immediate quality level switch to new quality level. this will pause the video if it was playing, flush the whole buffer, and fetch fragment matching with current position and requested quality level. then resume the video if needed once fetched fragment will have been buffered. set to -1 for automatic level selection
get : return next playback quality level (playback quality level for next buffered fragment). return -1 if next fragment not buffered yet
set : trigger a quality level switch for next fragment. this could eventually flush already buffered next fragment set to -1 for automatic level selection
get : return last loaded fragment quality level.
set : set quality level for next loaded fragment set to -1 for automatic level selection
getter : tell whether auto level selection is enabled or not
get/set : capping/max level value that could be used by automatic level selection algorithm
default value is -1 (no level capping)
get : return playback session stats
{
tech : 'flashls',
levelNb : total nb of quality level referenced in Manifest
levelStart : first quality level experienced by End User
autoLevelMin : min quality level experienced by End User (in auto mode)
autoLevelMax : max quality level experienced by End User (in auto mode)
autoLevelAvg : avg quality level experienced by End User (in auto mode)
autoLevelLast : last quality level experienced by End User (in auto mode)
autoLevelSwitch : nb of quality level switch in auto mode
autoLevelCappingMin : min auto quality level capping value
autoLevelCappingMax : max auto quality level capping value
autoLevelCappingLast : last auto quality level capping value
manualLevelMin : min quality level experienced by End User (in manual mode)
manualLevelMax : max quality level experienced by End User (in manual mode)
manualLevelLast : last quality level experienced by End User (in manual mode)
manualLevelSwitch : nb of quality level switch in manual mode
fragLastKbps : last fragment load bandwidth
fragMinKbps : min fragment load bandwidth
fragMaxKbps : max fragment load bandwidth
fragAvgKbps : avg fragment load bandwidth
fragLastLatency : last fragment load latency
fragMinLatency : min fragment load latency
fragMaxLatency : max fragment load latency
fragAvgLatency : avg fragment load latency
fragBuffered : total nb of buffered fragments
fragBufferedBytes : total nb of buffered bytes
fragSkipped : total nb of skipped fragments
fragChangedAuto : nb of frag played (loaded in auto mode)
fragChangedManual : nb of frag played (loaded in manual mode)
}
##Events
flashls fires a bunch of events, that could be registered as highlighted below:
hls.addEventListener(HLSEvent.MANIFEST_LOADED, _manifestLoadedHandler);
private function _manifestLoadedHandler(event : HLSEvent) : void {
var duration : Number = event.levels[_hls.startLevel].duration;
};
full list of Events is described below :
HLSEvent.MANIFEST_LOADING
- triggered when a manifest starts loading, triggered after a call to hls.load(url)- data: {url : manifest URL}
HLSEvent.MANIFEST_PARSED
- triggered after main manifest has been retrieved and parsed. playlist may not be playable yet, in case of adaptive streaming, start level playlist is not downloaded yet at that stage- data: { levels : array of quality level object }
HLSEvent.MANIFEST_LOADED
- when this event is received, main manifest and start level has been retrieved (playlist duration is available)- data: { levels : array of quality level object }
HLSEvent.LEVEL_LOADING
- triggered when a quality level starts loading- data: { level : level index}
HLSEvent.LEVEL_LOADED
- triggered when a quality level has been successfully loaded- data: { loadMetrics : HLSLoadMetrics }
HLSEvent.LEVEL_SWITCH
- triggered when a loading quality switch occurs (quality of next loaded fragment is switching. which is different from playback quality switch)- data: { level : level index}
HLSEvent.LEVEL_ENDLIST
- triggered when a live playlist is ended (i.e. a #EXT-X-ENDLIST tag is appearing)- data: none
HLSEvent.FRAGMENT_LOADING
- triggered when a fragment loading starts- data: {url : manifest URL}
HLSEvent.FRAGMENT_LOADED
- triggered after a fragment has been succesfully loaded- data: { loadMetrics : HLSLoadMetrics }
HLSEvent.FRAGMENT_LOAD_EMERGENCY_ABORTED
- triggered when fragment loading is aborted because of a sudden bandwidth drop- data: { loadMetrics : HLSLoadMetrics }
HLSEvent.FRAGMENT_PLAYING
- triggered when playback switches to a new fragment- data: { playMetrics : HLSPlayMetrics }
HLSEvent.FRAGMENT_SKIPPED
- triggered when a fragment has been skipped because of fragment load I/O error- data: { duration : skipped fragment duration }
HLSEvent.AUDIO_TRACKS_LIST_CHANGE
- triggered when available audio tracks list changes- data: none
HLSEvent.AUDIO_TRACK_SWITCH
- triggered when switching to a different audio track- data: none
HLSEvent.AUDIO_LEVEL_LOADING
- triggered when an alternate audio rendition playlist starts loading- data: { level : alternate audio track index}
HLSEvent.AUDIO_LEVEL_LOADED
- triggered when an alternate audio rendition playlist has been successfully loaded- data: { loadMetrics : HLSLoadMetrics }
HLSEvent.TAGS_LOADED
- triggered when FLV tags have been demultiplexed from loaded fragments- data: { loadMetrics : HLSLoadMetrics }
HLSEvent.LAST_VOD_FRAGMENT_LOADED
- triggered when last fragment of a VoD playlist has been successfully loaded- data: none
HLSEvent.ERROR
- triggered when any error occurs- data: { error : HLSError}
HLSEvent.MEDIA_TIME
- triggered when media position gets updated- data: { mediatime : HLSMediatime}
HLSEvent.PLAYBACK_STATE
- triggered when playback state gets changed- data: { state : HLSPlayStates}
HLSEvent.SEEK_STATE
- triggered when seek state gets changed- data: { state : HLSSeekStates}
HLSEvent.PLAYBACK_COMPLETE
- triggered when playback is completed (reach end of playback)- data: none
HLSEvent.PLAYLIST_DURATION_UPDATED
- triggered when playlist duration changes- data: { duration : new duration}
HLSEvent.ID3_UPDATED
- triggered when new ID3 tag is available (fired during playback at the right playback timestamp)- data: { ID3Data : Hex String of ID3 representation }
HLSEvent.STAGE_SET
- triggered when Stage object has been attached to hls instance- data: none
HLSEvent.FPS_DROP
- triggered when FPS drop in last monitoring period is higher than given threshold- data: { level : current playback quality level}
HLSEvent.FPS_DROP_LEVEL_CAPPING
- triggered when FPS drop triggers auto level capping- data: { level : max autolevel }
HLSEvent.FPS_DROP_SMOOTH_LEVEL_SWITCH
- triggered when FPS drop triggers a smooth auto level down switching- data: none
HLSEvent.LIVE_LOADING_STALLED
- triggered when fragment loading stalls when playing back live content- data: none