The DashAdapter module can be accessed using the MediaPlayer API getDashAdapter()

Methods

applyPatchToManifest(manifest, patch)

Takes a given patch and applies it to the provided manifest, assumes patch is valid for manifest

Parameters:
NameTypeDescription
manifestobject
patchobject

areMediaInfosEqual(mInfoOne, mInfoTwo) → {boolean}

Compares two mediaInfo objects

Parameters:
NameTypeDescription
mInfoOneMediaInfo
mInfoTwoMediaInfo
Returns:
Type: 
boolean

getAdaptationForType(periodIndex, type, streamInfo) → {null|object}

Returns the AdaptationSet for a given period index and a given mediaType.

Parameters:
NameTypeDescription
periodIndexnumber
typeMediaType
streamInfoobject
Returns:

adaptation

Type: 
null | object

getAllMediaInfoForType(streamInfo, type, externalManifest) → {Array}

Returns all the mediaInfos for a given mediaType and the corresponding streamInfo.

Parameters:
NameTypeDescription
streamInfoobject
typeMediaType
externalManifestobject

Set to null or undefined if no external manifest is to be used

Returns:

mediaArr

Type: 
Array

getAvailabilityStartTime(externalManifest) → {number}

Returns the availabilityStartTime as specified in the manifest

Parameters:
NameTypeDescription
externalManifestobject

Omit this value if no external manifest should be used

Returns:

availabilityStartTime

Type: 
number

getBandwidthForRepresentation(representationId, periodIdx) → {number}

Returns the bandwidth for a given representation id and the corresponding period index

Parameters:
NameTypeDescription
representationIdnumber
periodIdxnumber
Returns:

bandwidth

Type: 
number

getCodec(adaptation, representationId, addResolutionInfo) → {String}

Returns the codec for a given adaptation set and a given representation id.

Parameters:
NameTypeDescription
adaptationobject
representationIdnumber
addResolutionInfoboolean

Defines whether to include resolution information in the output

Returns:

codec

Type: 
String

getContentSteering(manifest) → {object}

Returns the ContentSteering element of the MPD

Parameters:
NameTypeDescription
manifestobject
Returns:

contentSteering

Type: 
object

getDuration(externalManifest) → {number}

Returns the duration of the MPD

Parameters:
NameTypeDescription
externalManifestobject

Omit this value if no external manifest should be used

Returns:

duration

Type: 
number

getIndexForRepresentation(representationId, periodIdx) → {number}

Returns the index for a given representation id

Parameters:
NameTypeDescription
representationIdstring
periodIdxnumber
Returns:

index

Type: 
number

getIsDynamic(externalManifest) → {boolean}

Returns a boolean indicating if the manifest is dynamic or not

Parameters:
NameTypeDescription
externalManifestobject

Omit this value if no external manifest should be used

Returns:
Type: 
boolean

getIsMain(adaptation) → {boolean}

Checks if the role of the specified AdaptationSet is set to main

Parameters:
NameTypeDescription
adaptationobject
Returns:
Type: 
boolean

getIsPatch(manifest) → {boolean}

Checks if the manifest is actually just a patch manifest

Parameters:
NameTypeDescription
manifestobject
Returns:
Type: 
boolean

getIsTypeOf(adaptation, type) → {boolean}

Checks if the given AdaptationSet is from the given media type

Parameters:
NameTypeDescription
adaptationobject
typestring
Returns:
Type: 
boolean

getLocation(manifest) → {String}

Returns the location element of the MPD

Parameters:
NameTypeDescription
manifestobject
Returns:

location

Type: 
String

getManifestUpdatePeriod(manifest, latencyOfLastUpdate) → {NaN|number}

Returns the manifest update period used for dynamic manifests

Parameters:
NameTypeDefaultDescription
manifestobject
latencyOfLastUpdatenumber0
Returns:

manifestUpdatePeriod

Type: 
NaN | number

getMaxIndexForBufferType(bufferType, periodIdx) → {number}

This method returns the current max index based on what is defined in the MPD.

Parameters:
NameTypeDescription
bufferTypestring

String 'audio' or 'video',

periodIdxnumber

Make sure this is the period index not id

Returns:
Type: 
number

getMediaInfoForType(streamInfo, type) → {null|MediaInfo}

Returns a MediaInfo object for a given media type and the corresponding streamInfo.

Parameters:
NameTypeDescription
streamInfoobject
typeMediaType
Returns:

mediaInfo

Type: 
null | MediaInfo

getMpd(externalManifest) → {object}

Returns an MPD object

Parameters:
NameTypeDescription
externalManifestobject

Omit this value if no external manifest should be used

Returns:

MPD

Type: 
object

getPatchLocation(manifest) → {Array.<PatchLocation>}

Returns the patch locations of the MPD if existing and if they are still valid

Parameters:
NameTypeDescription
manifestobject
Returns:

patch location

Type: 
Array.<PatchLocation>

getPeriodById(id) → {object|null}

Returns the voPeriod object for a given id

Parameters:
NameTypeDescription
idString
Returns:
Type: 
object | null

getProducerReferenceTimes(streamInfo, mediaInfo) → {object}

Returns the ProducerReferenceTimes as saved in the DashManifestModel if present

Parameters:
NameTypeDescription
streamInfoobject
mediaInfoobject
Returns:

producerReferenceTimes

Type: 
object

getPublishTime(manifest) → {Date|null}

Returns the publish time from the manifest

Parameters:
NameTypeDescription
manifestobject
Returns:

publishTime

Type: 
Date | null

getRealAdaptation(streamInfo, mediaInfo) → {object}

Returns the AdaptationSet as saved in the DashManifestModel

Parameters:
NameTypeDescription
streamInfoobject
mediaInfoobject
Returns:

realAdaptation

Type: 
object

getRealPeriodByIndex(index) → {object}

Returns the period as defined in the DashManifestModel for a given index

Parameters:
NameTypeDescription
indexnumber
Returns:
Type: 
object

getRegularPeriods(externalManifest) → {Array}

Returns all periods of the MPD

Parameters:
NameTypeDescription
externalManifestobject

Omit this value if no external manifest should be used

Returns:

periods

Type: 
Array

getSuggestedPresentationDelay() → {String}

Returns the suggestedPresentationDelay as specified in the manifest

Returns:

suggestedPresentationDelay

Type: 
String

getUTCTimingSources() → {Array}

Returns the UTC Timing Sources specified in the manifest

Returns:

utcTimingSources

Type: 
Array

getVoRepresentations(mediaInfo) → {Array}

Returns all voRepresentations for a given mediaInfo

Parameters:
NameTypeDescription
mediaInfoobject
Returns:

voReps

Type: 
Array

isPatchValid(manifest, patch) → {boolean}

Checks if the supplied manifest is compatible for application of the supplied patch

Parameters:
NameTypeDescription
manifestobject
patchobject
Returns:
Type: 
boolean