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
return current playback relative position( relative to live main playlist sliding), in seconds
Return the live main playlist sliding since previous out of buffer seek()
, in seconds
Return the live alternate audio playlist sliding since previous out of buffer seek()
,in seconds
Return the current buffer length, in seconds
Return the current back buffer length, in seconds
Return the current watched time in seconds, since last call to hls.load(URL)
Return the total number of dropped video frames, since last call to hls.load(URL)
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)
start/restart playlist/fragment loading. this is only effective if MANIFEST_PARSED event has been triggered
##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