public final class MergingMediaSource extends CompositeMediaSource<java.lang.Integer>
MediaSources.
The Timelines of the sources being merged must have the same number of periods.
| Modifier and Type | Class and Description |
|---|---|
static class |
MergingMediaSource.IllegalMergeException
Thrown when a
MergingMediaSource cannot merge its sources. |
MediaSource.MediaPeriodId, MediaSource.SourceInfoRefreshListener| Constructor and Description |
|---|
MergingMediaSource(CompositeSequenceableLoaderFactory compositeSequenceableLoaderFactory,
MediaSource... mediaSources) |
MergingMediaSource(MediaSource... mediaSources) |
| Modifier and Type | Method and Description |
|---|---|
MediaPeriod |
createPeriod(MediaSource.MediaPeriodId id,
Allocator allocator)
Returns a new
MediaPeriod identified by periodId. |
void |
maybeThrowSourceInfoRefreshError()
Throws any pending error encountered while loading or refreshing source information.
|
protected void |
onChildSourceInfoRefreshed(java.lang.Integer id,
MediaSource mediaSource,
Timeline timeline,
java.lang.Object manifest)
Called when the source info of a child source has been refreshed.
|
void |
prepareSourceInternal(ExoPlayer player,
boolean isTopLevelSource)
Starts source preparation.
|
void |
releasePeriod(MediaPeriod mediaPeriod)
Releases the period.
|
void |
releaseSourceInternal()
Releases the source.
|
getMediaPeriodIdForChildMediaPeriodId, getMediaTimeForChildMediaTime, getWindowIndexForChildWindowIndex, prepareChildSource, releaseChildSourceaddEventListener, createEventDispatcher, createEventDispatcher, createEventDispatcher, prepareSource, refreshSourceInfo, releaseSource, removeEventListenerpublic MergingMediaSource(MediaSource... mediaSources)
mediaSources - The MediaSources to merge.public MergingMediaSource(CompositeSequenceableLoaderFactory compositeSequenceableLoaderFactory, MediaSource... mediaSources)
compositeSequenceableLoaderFactory - A factory to create composite
SequenceableLoaders for when this media source loads data from multiple streams
(video, audio etc...).mediaSources - The MediaSources to merge.public void prepareSourceInternal(ExoPlayer player, boolean isTopLevelSource)
BaseMediaSourceBaseMediaSource.releaseSourceInternal().prepareSourceInternal in class CompositeMediaSource<java.lang.Integer>player - The player for which this source is being prepared.isTopLevelSource - Whether this source has been passed directly to ExoPlayer.prepare(MediaSource) or ExoPlayer.prepare(MediaSource, boolean,
boolean).public void maybeThrowSourceInfoRefreshError()
throws java.io.IOException
MediaSourceShould not be called directly from application code.
maybeThrowSourceInfoRefreshError in interface MediaSourcemaybeThrowSourceInfoRefreshError in class CompositeMediaSource<java.lang.Integer>java.io.IOExceptionpublic MediaPeriod createPeriod(MediaSource.MediaPeriodId id, Allocator allocator)
MediaSourceMediaPeriod identified by periodId. This method may be called
multiple times with the same period identifier 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.MediaPeriod.public void releasePeriod(MediaPeriod mediaPeriod)
MediaSourceShould not be called directly from application code.
mediaPeriod - The period to release.public void releaseSourceInternal()
BaseMediaSourceBaseMediaSource.prepareSourceInternal(ExoPlayer, boolean).releaseSourceInternal in class CompositeMediaSource<java.lang.Integer>protected void onChildSourceInfoRefreshed(java.lang.Integer id,
MediaSource mediaSource,
Timeline timeline,
@Nullable
java.lang.Object manifest)
CompositeMediaSourceonChildSourceInfoRefreshed in class CompositeMediaSource<java.lang.Integer>id - 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.