ExoPlayer unterstützt DASH mit mehreren Containerformaten. Medienstreams müssen demultiplext werden. Das bedeutet, dass Video, Audio und Text in separaten AdaptationSet
-Elementen im DASH-Manifest definiert werden müssen. CEA-608 ist eine Ausnahme, wie in der folgenden Tabelle beschrieben. Die enthaltenen Audio- und Video-Sample-Formate müssen ebenfalls unterstützt werden. Weitere Informationen finden Sie im Abschnitt Sample-Formate.
Funktion | Unterstützt | Kommentare |
---|---|---|
Container | ||
FMP4 | JA | Nur demultiplexierte Streams |
WebM | JA | Nur demultiplexierte Streams |
Matroska | JA | Nur demultiplexierte Streams |
MPEG-TS | NEIN | Kein Support geplant |
Untertitel | ||
TTML | JA | RAW oder in FMP4 gemäß ISO/IEC 14496-30 eingebettet |
WebVTT | JA | Roh oder in FMP4 gemäß ISO/IEC 14496-30 eingebettet |
CEA-608 | JA | In FMP4 eingebettet, wenn sie mit SCTE-Beschreibungen für die Barrierefreiheit signalisiert werden |
CEA-708 | JA | In FMP4 eingebettet, wenn sie mit SCTE-Beschreibungen für die Barrierefreiheit signalisiert werden |
Metadaten | ||
EMSG-Metadaten | JA | In FMP4 eingebettet |
Inhaltsschutz | ||
Widevine | JA | „cenc“-Schema: API 19 und höher; „cbcs“-Schema: API 25 und höher |
PlayReady SL2000 | JA | Android TV, nur „cenc“-Schema |
ClearKey | JA | API 21 und höher, nur Schema „cenc“ |
Livewiedergabe | ||
Regelmäßige Livewiedergabe | JA | |
CMAF-Livewiedergabe mit extrem niedriger Latenz | JA | |
Common Media Client Data (CMCD) | JA | Integrationsleitfaden |
MediaItem verwenden
Wenn du einen DASH-Stream abspielen möchtest, benötigst du das DASH-Modul.
Kotlin
implementation("androidx.media3:media3-exoplayer-dash:1.4.1")
Groovy
implementation "androidx.media3:media3-exoplayer-dash:1.4.1"
Du kannst dann eine MediaItem
für eine DASH-MPD-URI erstellen und an den Player übergeben.
Kotlin
// Create a player instance. val player = ExoPlayer.Builder(context).build() // Set the media item to be played. player.setMediaItem(MediaItem.fromUri(dashUri)) // Prepare the player. player.prepare()
Java
// Create a player instance. ExoPlayer player = new ExoPlayer.Builder(context).build(); // Set the media item to be played. player.setMediaItem(MediaItem.fromUri(dashUri)); // Prepare the player. player.prepare();
Wenn dein URI nicht auf .mpd
endet, kannst du MimeTypes.APPLICATION_MPD
an setMimeType
von MediaItem.Builder
übergeben, um den Inhaltstyp explizit anzugeben.
ExoPlayer passt sich automatisch zwischen den im Manifest definierten Darstellungen an und berücksichtigt dabei sowohl die verfügbare Bandbreite als auch die Gerätefunktionen.
DashMediaSource verwenden
Wenn du mehr Anpassungsoptionen benötigst, kannst du statt einer MediaItem
eine DashMediaSource
erstellen und direkt an den Player übergeben.
Kotlin
val dataSourceFactory: DataSource.Factory = DefaultHttpDataSource.Factory() // Create a dash media source pointing to a dash manifest uri. val mediaSource: MediaSource = DashMediaSource.Factory(dataSourceFactory).createMediaSource(MediaItem.fromUri(dashUri)) // Create a player instance which gets an adaptive track selector by default. val player = ExoPlayer.Builder(context).build() // Set the media source to be played. player.setMediaSource(mediaSource) // Prepare the player. player.prepare()
Java
DataSource.Factory dataSourceFactory = new DefaultHttpDataSource.Factory(); // Create a dash media source pointing to a dash manifest uri. MediaSource mediaSource = new DashMediaSource.Factory(dataSourceFactory) .createMediaSource(MediaItem.fromUri(dashUri)); // Create a player instance which gets an adaptive track selector by default. ExoPlayer player = new ExoPlayer.Builder(context).build(); // Set the media source to be played. player.setMediaSource(mediaSource); // Prepare the player. player.prepare();
Auf das Manifest zugreifen
Sie können das aktuelle Manifest durch Aufrufen von Player.getCurrentManifest
abrufen.
Für DASH solltest du das zurückgegebene Objekt in DashManifest
umwandeln. Der onTimelineChanged
-Callback von Player.Listener
wird ebenfalls aufgerufen, wenn das Manifest geladen wird. Bei On-Demand-Inhalten geschieht dies einmal, bei Livestreams möglicherweise mehrmals. Das folgende Code-Snippet zeigt, wie eine App etwas tun kann, wenn das Manifest geladen wird.
Kotlin
player.addListener( object : Player.Listener { override fun onTimelineChanged(timeline: Timeline, @TimelineChangeReason reason: Int) { val manifest = player.currentManifest if (manifest is DashManifest) { // Do something with the manifest. } } } )
Java
player.addListener( new Player.Listener() { @Override public void onTimelineChanged( Timeline timeline, @Player.TimelineChangeReason int reason) { Object manifest = player.getCurrentManifest(); if (manifest != null) { DashManifest dashManifest = (DashManifest) manifest; // Do something with the manifest. } } });
Wiedergabe anpassen
Mit ExoPlayer hast du mehrere Möglichkeiten, die Wiedergabe an die Anforderungen deiner App anzupassen. Beispiele finden Sie auf der Seite „Anpassen“.