Home Reference Source
import {FragmentTracker} from 'hls.js/src/controller/fragment-tracker.ts'
public class | source

FragmentTracker

Constructor Summary

Public Constructor
public

Member Summary

Public Members
public
public
public
public

fragments: Partial

public

hls: *

public

Method Summary

Public Methods
public
public

detectEvictedFragments(elementaryStream: SourceBufferName, timeRange: TimeRanges)

Partial fragments effected by coded frame eviction will be removed The browser will unload parts of the buffer to free up memory for new buffer data Fragments will need to be reloaded when the buffer is freed up, removing partial fragments will allow them to reload(since there might be parts that are still playable)

public

detectPartialFragments(data: FragBufferedData)

Checks if the fragment passed in is loaded in the buffer properly Partially loaded fragments will be registered as a partial fragment

public

getAppendedFrag(position: number, levelType: PlaylistLevelType): *

Return a Fragment with an appended range that matches the position and levelType.

public

getBufferedFrag(position: number, levelType: PlaylistLevelType): *

Return a buffered Fragment that matches the position and levelType.

public

getBufferedTimes(fragment: Fragment, part: undefined, timeRange: TimeRanges): FragmentBufferedRange

public

Gets the partial fragment for a certain time

public

getState(fragment: Fragment): FragmentState

Return the fragment state when a fragment never loaded or if it partially loaded

public

Return true if fragment tracker has the fragment.

public

isTimeBuffered(startPTS: number, endPTS: number, timeRange: TimeRanges): boolean

public

onBufferAppended(event: undefined, data: BufferAppendedData)

Fires when the buffer is updated

public

onFragBuffered(event: undefined, data: FragBufferedData)

Fires after a fragment has been loaded into the source buffer

public

onFragLoaded(event: undefined, data: FragLoadedData)

Fires when a fragment loading is completed

public

Remove all fragments from fragment tracker.

public

Remove a fragment from fragment tracker until it is loaded again

Private Methods
private
private

Public Constructors

public constructor() source

Public Members

public activeFragment: * source

public activePart: * source

public bufferPadding: number source

public fragments: Partial source

public hls: * source

public timeRanges: * source

Public Methods

public destroy() source

public detectEvictedFragments(elementaryStream: SourceBufferName, timeRange: TimeRanges) source

Partial fragments effected by coded frame eviction will be removed The browser will unload parts of the buffer to free up memory for new buffer data Fragments will need to be reloaded when the buffer is freed up, removing partial fragments will allow them to reload(since there might be parts that are still playable)

Params:

NameTypeAttributeDescription
elementaryStream SourceBufferName
timeRange TimeRanges

public detectPartialFragments(data: FragBufferedData) source

Checks if the fragment passed in is loaded in the buffer properly Partially loaded fragments will be registered as a partial fragment

Params:

NameTypeAttributeDescription
data FragBufferedData

public getAppendedFrag(position: number, levelType: PlaylistLevelType): * source

Return a Fragment with an appended range that matches the position and levelType. If not found any Fragment, return null

Params:

NameTypeAttributeDescription
position number
levelType PlaylistLevelType

Return:

*

public getBufferedFrag(position: number, levelType: PlaylistLevelType): * source

Return a buffered Fragment that matches the position and levelType. A buffered Fragment is one whose loading, parsing and appending is done (completed or "partial" meaning aborted). If not found any Fragment, return null

Params:

NameTypeAttributeDescription
position number
levelType PlaylistLevelType

Return:

*

public getBufferedTimes(fragment: Fragment, part: undefined, timeRange: TimeRanges): FragmentBufferedRange source

Params:

NameTypeAttributeDescription
fragment Fragment
part undefined
timeRange TimeRanges

Return:

FragmentBufferedRange

public getPartialFragment(time: number): * source

Gets the partial fragment for a certain time

Params:

NameTypeAttributeDescription
time number

Return:

*

public getState(fragment: Fragment): FragmentState source

Return the fragment state when a fragment never loaded or if it partially loaded

Params:

NameTypeAttributeDescription
fragment Fragment

Return:

FragmentState

public hasFragment(fragment: Fragment): boolean source

Return true if fragment tracker has the fragment.

Params:

NameTypeAttributeDescription
fragment Fragment

Return:

boolean

public isTimeBuffered(startPTS: number, endPTS: number, timeRange: TimeRanges): boolean source

Params:

NameTypeAttributeDescription
startPTS number
endPTS number
timeRange TimeRanges

Return:

boolean

public onBufferAppended(event: undefined, data: BufferAppendedData) source

Fires when the buffer is updated

Params:

NameTypeAttributeDescription
event undefined
data BufferAppendedData

public onFragBuffered(event: undefined, data: FragBufferedData) source

Fires after a fragment has been loaded into the source buffer

Params:

NameTypeAttributeDescription
event undefined
data FragBufferedData

public onFragLoaded(event: undefined, data: FragLoadedData) source

Fires when a fragment loading is completed

Params:

NameTypeAttributeDescription
event undefined
data FragLoadedData

public removeAllFragments() source

Remove all fragments from fragment tracker.

public removeFragment(fragment: Fragment) source

Remove a fragment from fragment tracker until it is loaded again

Params:

NameTypeAttributeDescription
fragment Fragment

Private Methods

private _registerListeners() source

private _unregisterListeners() source