ExoPlayer unterstützt DASH mit mehreren Containerformaten. Media-Streams müssen
Das heißt, Video, Audio und Text müssen getrennt voneinander definiert werden.
AdaptationSet
-Elemente im DASH-Manifest (CEA-608 ist eine Ausnahme, da
wie in der Tabelle unten beschrieben). Die enthaltenen Audio- und Video-Beispielformate müssen
auch unterstützt werden (siehe
Beispielformate.
Funktion | Unterstützt | Kommentare |
---|---|---|
Container | ||
FMP4 | JA | Nur demuxierte Streams |
WebM | JA | Nur demuxierte Streams |
Matroska | JA | Nur Demuxed-Streams |
MPEG-TS | NEIN | Keine Unterstützung geplant |
Untertitel | ||
TTML | JA | RAW oder in FMP4 gemäß ISO/IEC 14496-30 eingebettet |
WebVTT | JA | RAW oder in FMP4 gemäß ISO/IEC 14496-30 eingebettet |
CEA-608 | JA | In FMP4 eingebettet, wenn sie mithilfe von SCTE-Bedienungshilfen-Deskriptoren signalisiert wird |
CEA-708 | JA | In FMP4 eingebettet, wenn es mithilfe von SCTE-Bedienungshilfen-Deskriptoren signalisiert wird |
Metadaten | ||
EMSG-Metadaten | JA | In FMP4 eingebettet |
Inhaltsschutz | ||
Widevine | JA | „cenc“ Schema: API 19+; „cbcs“ Schema: API 25+ |
PlayReady SL2000 | JA | Android TV, „cenc“ Nur Schema |
ClearKey | JA | API 21 oder höher, „cenc“ Nur Schema |
Live-Wiedergabe | ||
Regelmäßige Live-Wiedergabe | JA | |
CMAF-Livewiedergabe mit extrem niedriger Latenz | JA | |
Common Media Client Data (CMCD) | JA | Integrationsleitfaden |
MediaItem verwenden
Zur Wiedergabe eines DASH-Streams ist das DASH-Modul erforderlich.
Kotlin
implementation("androidx.media3:media3-exoplayer-dash:1.4.1")
Cool
implementation "androidx.media3:media3-exoplayer-dash:1.4.1"
Du kannst dann eine MediaItem
für einen 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 Ihr URI nicht auf .mpd
endet, können Sie MimeTypes.APPLICATION_MPD
übergeben.
bis setMimeType
von MediaItem.Builder
, um explizit den Typ des
Inhalte.
Der ExoPlayer passt sich automatisch zwischen den im unter Berücksichtigung der verfügbaren Bandbreite und der Gerätefunktionen.
DashMediaSource verwenden
Weitere Anpassungsoptionen erhalten Sie, wenn Sie eine DashMediaSource
erstellen und übergeben.
direkt an den Spieler statt an MediaItem
.
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
Du kannst das aktuelle Manifest abrufen, indem du Player.getCurrentManifest
aufrufst.
Für DASH sollten Sie das zurückgegebene Objekt in DashManifest
umwandeln. Die
Der onTimelineChanged
-Callback von Player.Listener
wird auch immer dann aufgerufen,
wird das Manifest geladen. Dies geschieht einmal bei On-Demand-Inhalten und
bei Live-Inhalten häufig vor. Das folgende Code-Snippet zeigt, wie eine App
Aktionen ausführen können, 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 können Sie die Wiedergabe auf verschiedene die Anforderungen der App zu erfüllen. Beispiele finden Sie auf der Seite „Anpassen“.