Optional
abrThe source's ABR configuration.
- Available since v3.1.0.
- Overrides PlayerConfiguration.abr.
- Used for DASH and LL-HLS streams.
Optional
contentThe content protection parameters for the media resource.
Optional
crossThe cross-origin setting of the source.
Optional
dashThe configuration for controlling playback of an MPEG-DASH stream.
Optional
drmThe content protection parameters for the media resource.
Superseded by TypedSource.contentProtection.
Optional
hlsThe configuration for controlling playback of an HLS stream.
Optional
hlsWhether the player should parse and expose date ranges from HLS manifests.
Optional
ignoreA list of embedded TextTrackTypes to ignore when parsing media segments.
Optional
integrationThe integration ID of the source.
Optional
latencyThe source's latency configuration.
Optional
lcevcWhether this source should be played using the LCEVC sdk.
Optional
liveThe offset in seconds used to determine the live point. This live point is the end of the manifest minus the provided offset.
- Available since v2.35.0.
- Will be overridden by SourceLatencyConfiguration.targetOffset if it is specified.
Optional
lowWhether the source should be played in the low-latency-mode of the player.
Optional
seamlessWhether to seamlessly switch between discontinuities or periods.
The player supports two strategies for handling a switch between two discontinuities in an HLS stream or two periods in an MPEG-DASH stream:
- Seamless: Once the player is done buffering the current discontinuity/period, it immediately starts buffering the next
discontinuity/period. This requires that the current discontinuity/period and the next discontinuity/period have compatible codecs and content protection,
or that the platform supports buffering different codecs in a single player.
Because the next discontinuity/period is preloaded ahead of time, this makes the actual switch between discontinuities/periods (almost) completely seamless.
- Hard: The player waits until playback reaches the end of the current discontinuity/period before buffering and playing the next
discontinuity/period. Because the buffering is not done ahead of time, this may result in a noticeable stall at the start of the next discontinuity/period.
However, this strategy does not require any special platform support, so it works on any platform or device.
By default, the player will automatically choose between a seamless or a hard discontinuity/period switch based on the codecs and content protection of the two discontinuities/periods, and the support information reported by the platform. However, if you notice that the player makes an incorrect decision on certain streams or platforms, you can use this option to override its behavior as a stopgap solution. (You should still report this problem to THEOplayer support, so we can improve the player's default behavior and you can remove this override.)
Optional
srcThe source URL of the media resource.
The Server-side Ad Insertion parameters for the media resource.
Optional
timeThe URL of a time server used by the player to synchronise the time in DASH sources.
- Available since v2.47.0.
- The time server should return time in ISO-8601 format.
- Overrides the time server provided the DASH manifest's <UTCTiming>
.
- Only this source will use the time server. Alternatively, for all source use SourceConfiguration.timeServer.
Optional
typeThe content type (MIME type) of the media resource, represented by a value from the following list:
- 'application/dash+xml'
: The media resource is an MPEG-DASH stream.
- 'application/x-mpegURL'
or 'application/vnd.apple.mpegurl'
: The media resource is an HLS stream.
- 'video/mp4'
, 'video/webm'
and other formats: The media resource should use native HTML5 playback if supported by the browser.
- 'application/vnd.theo.hesp+json'
: The media resource is an HESP stream.
- 'millicast'
: The media resource is a Millicast stream.
- 'theolive'
: The media resource is a THEOlive stream.
Optional
useWhether the player is allowed to use credentials for cross-origin requests.
Optional
use(Experimental) Whether to use ManagedMediaSource
if available.
- Available since v6.2.0.
- At the moment, this requires iOS 17.1 beta 2 or higher, with the "Managed Media Source API" feature flag
turned on in the Advanced settings of Safari.
- Ignored if BaseSource.useNativePlayback is true
.
Optional
useWhether this source should be played using native playback.
Describes a source of the Imagine integration.