FragmentTracker
Constructor Summary
Public Constructor | ||
public |
|
Member Summary
Public Members | ||
public |
|
|
public |
activePart: * |
|
public |
|
|
public |
fragments: Partial |
|
public |
hls: * |
|
public |
timeRanges: * |
Method Summary
Public Methods | ||
public |
destroy() |
|
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 |
getPartialFragment(time: number): * Gets the partial fragment for a certain time |
|
public |
Return the fragment state when a fragment never loaded or if it partially loaded |
|
public |
hasFragment(fragment: Fragment): boolean 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 |
removeFragment(fragment: Fragment) 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 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:
Name | Type | Attribute | Description |
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:
Name | Type | Attribute | Description |
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:
Name | Type | Attribute | Description |
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:
Name | Type | Attribute | Description |
position | number | ||
levelType | PlaylistLevelType |
Return:
* |
public getBufferedTimes(fragment: Fragment, part: undefined, timeRange: TimeRanges): FragmentBufferedRange source
Params:
Name | Type | Attribute | Description |
fragment | Fragment | ||
part | undefined | ||
timeRange | TimeRanges |
Return:
FragmentBufferedRange |
public getPartialFragment(time: number): * source
Gets the partial fragment for a certain time
Params:
Name | Type | Attribute | Description |
time | number |
Return:
* |
public getState(fragment: Fragment): FragmentState source
Return the fragment state when a fragment never loaded or if it partially loaded
Params:
Name | Type | Attribute | Description |
fragment | Fragment |
Return:
FragmentState |
public hasFragment(fragment: Fragment): boolean source
Return true if fragment tracker has the fragment.
Params:
Name | Type | Attribute | Description |
fragment | Fragment |
public isTimeBuffered(startPTS: number, endPTS: number, timeRange: TimeRanges): boolean source
Params:
Name | Type | Attribute | Description |
startPTS | number | ||
endPTS | number | ||
timeRange | TimeRanges |
public onBufferAppended(event: undefined, data: BufferAppendedData) source
Fires when the buffer is updated
Params:
Name | Type | Attribute | Description |
event | undefined | ||
data | BufferAppendedData |
public onFragBuffered(event: undefined, data: FragBufferedData) source
Fires after a fragment has been loaded into the source buffer
Params:
Name | Type | Attribute | Description |
event | undefined | ||
data | FragBufferedData |
public onFragLoaded(event: undefined, data: FragLoadedData) source
Fires when a fragment loading is completed
Params:
Name | Type | Attribute | Description |
event | undefined | ||
data | FragLoadedData |
public removeFragment(fragment: Fragment) source
Remove a fragment from fragment tracker until it is loaded again
Params:
Name | Type | Attribute | Description |
fragment | Fragment |