public final class AdsMediaSource extends CompositeMediaSource<MediaSource.MediaPeriodId>
MediaSource
that inserts ads linearly with a provided content media source. This source
cannot be used as a child source in a composition. It must be the top-level source used to
prepare the player.Modifier and Type | Class and Description |
---|---|
static class |
AdsMediaSource.AdLoadException
Wrapper for exceptions that occur while loading ads, which are notified via
MediaSourceEventListener#onLoadError(int, MediaPeriodId, LoadEventInfo, MediaLoadData,
IOException, boolean) . |
static interface |
AdsMediaSource.MediaSourceFactory
Factory for creating
MediaSource s to play ad media. |
MediaSource.MediaPeriodId, MediaSource.SourceInfoRefreshListener
Constructor and Description |
---|
AdsMediaSource(MediaSource contentMediaSource,
AdsMediaSource.MediaSourceFactory adMediaSourceFactory,
AdsLoader adsLoader,
AdsLoader.AdViewProvider adViewProvider)
Constructs a new source that inserts ads linearly with the content specified by
contentMediaSource . |
AdsMediaSource(MediaSource contentMediaSource,
DataSource.Factory dataSourceFactory,
AdsLoader adsLoader,
AdsLoader.AdViewProvider adViewProvider)
Constructs a new source that inserts ads linearly with the content specified by
contentMediaSource . |
Modifier and Type | Method and Description |
---|---|
MediaPeriod |
createPeriod(MediaSource.MediaPeriodId id,
Allocator allocator,
long startPositionUs)
Returns a new
MediaPeriod identified by periodId . |
protected MediaSource.MediaPeriodId |
getMediaPeriodIdForChildMediaPeriodId(MediaSource.MediaPeriodId childId,
MediaSource.MediaPeriodId mediaPeriodId)
Returns the
MediaPeriodId in the composite source corresponding to the specified MediaPeriodId in a child source. |
java.lang.Object |
getTag()
Returns the tag set on the media source, or null if none was set.
|
protected void |
onChildSourceInfoRefreshed(MediaSource.MediaPeriodId mediaPeriodId,
MediaSource mediaSource,
Timeline timeline,
java.lang.Object manifest)
Called when the source info of a child source has been refreshed.
|
void |
prepareSourceInternal(TransferListener mediaTransferListener)
Starts source preparation.
|
void |
releasePeriod(MediaPeriod mediaPeriod)
Releases the period.
|
void |
releaseSourceInternal()
Releases the source.
|
getMediaTimeForChildMediaTime, getWindowIndexForChildWindowIndex, maybeThrowSourceInfoRefreshError, prepareChildSource, releaseChildSource
addEventListener, createEventDispatcher, createEventDispatcher, createEventDispatcher, prepareSource, refreshSourceInfo, releaseSource, removeEventListener
public AdsMediaSource(MediaSource contentMediaSource, DataSource.Factory dataSourceFactory, AdsLoader adsLoader, AdsLoader.AdViewProvider adViewProvider)
contentMediaSource
. Ad media is loaded using ExtractorMediaSource
.contentMediaSource
- The MediaSource
providing the content to play.dataSourceFactory
- Factory for data sources used to load ad media.adsLoader
- The loader for ads.adViewProvider
- Provider of views for the ad UI.public AdsMediaSource(MediaSource contentMediaSource, AdsMediaSource.MediaSourceFactory adMediaSourceFactory, AdsLoader adsLoader, AdsLoader.AdViewProvider adViewProvider)
contentMediaSource
.contentMediaSource
- The MediaSource
providing the content to play.adMediaSourceFactory
- Factory for media sources used to load ad media.adsLoader
- The loader for ads.adViewProvider
- Provider of views for the ad UI.@Nullable public java.lang.Object getTag()
MediaSource
public void prepareSourceInternal(@Nullable TransferListener mediaTransferListener)
BaseMediaSource
BaseMediaSource.releaseSourceInternal()
.prepareSourceInternal
in class CompositeMediaSource<MediaSource.MediaPeriodId>
mediaTransferListener
- The transfer listener which should be informed of any media data
transfers. May be null if no listener is available. Note that this listener should usually
be only informed of transfers related to the media loads and not of auxiliary loads for
manifests and other data.public MediaPeriod createPeriod(MediaSource.MediaPeriodId id, Allocator allocator, long startPositionUs)
MediaSource
MediaPeriod
identified by periodId
. This method may be called
multiple times without an intervening call to MediaSource.releasePeriod(MediaPeriod)
.
Should not be called directly from application code.
id
- The identifier of the period.allocator
- An Allocator
from which to obtain media buffer allocations.startPositionUs
- The expected start position, in microseconds.MediaPeriod
.public void releasePeriod(MediaPeriod mediaPeriod)
MediaSource
Should not be called directly from application code.
mediaPeriod
- The period to release.public void releaseSourceInternal()
BaseMediaSource
BaseMediaSource.prepareSourceInternal(TransferListener)
.releaseSourceInternal
in class CompositeMediaSource<MediaSource.MediaPeriodId>
protected void onChildSourceInfoRefreshed(MediaSource.MediaPeriodId mediaPeriodId, MediaSource mediaSource, Timeline timeline, @Nullable java.lang.Object manifest)
CompositeMediaSource
onChildSourceInfoRefreshed
in class CompositeMediaSource<MediaSource.MediaPeriodId>
mediaPeriodId
- The unique id used to prepare the child source.mediaSource
- The child source whose source info has been refreshed.timeline
- The timeline of the child source.manifest
- The manifest of the child source.@Nullable protected MediaSource.MediaPeriodId getMediaPeriodIdForChildMediaPeriodId(MediaSource.MediaPeriodId childId, MediaSource.MediaPeriodId mediaPeriodId)
CompositeMediaSource
MediaPeriodId
in the composite source corresponding to the specified MediaPeriodId
in a child source. The default implementation does not change the media period
id.getMediaPeriodIdForChildMediaPeriodId
in class CompositeMediaSource<MediaSource.MediaPeriodId>
childId
- The unique id used to prepare the child source.mediaPeriodId
- A MediaPeriodId
of the child source.MediaPeriodId
in the composite source. Null if no
corresponding media period id can be determined.