ExoPlayer unterstützt DASH mit mehreren Containerformaten. Medienstreams müssen entnommen werden. Das heißt, Video, Audio und Text müssen im DASH-Manifest in separaten AdaptationSet
-Elementen definiert sein. CEA-608 ist eine Ausnahme, wie in der Tabelle unten beschrieben. Die enthaltenen Audio- und Video-Beispielformate müssen ebenfalls unterstützt werden. Weitere Informationen finden Sie im Abschnitt Beispielformate.
Funktion | Unterstützt | Kommentare |
---|---|---|
Container | ||
FMP4 | JA | Nur demuxtisierte Streams |
WebM | JA | Nur demuxtisierte Streams |
Matroska | JA | Nur demuxtisierte Streams |
MPEG-TS | NEIN | Kein Support geplant |
Untertitel | ||
TTML | JA | Unbearbeitet oder gemäß ISO/IEC 14496-30 in FMP4 eingebettet |
WebVTT | JA | Unbearbeitet oder gemäß ISO/IEC 14496-30 in FMP4 eingebettet |
CEA-608 | JA | In FMP4 eingebettet, wenn SCTE-Deskriptoren für die Barrierefreiheit verwendet werden |
CEA-708 | JA | In FMP4 eingebettet, wenn SCTE-Deskriptoren für die Barrierefreiheit verwendet werden |
Metadaten | ||
EMSG-Metadaten | JA | Eingebettet in FMP4 |
Inhaltsschutz | ||
Widevine | JA | Schema „cenc“: API 19+; „cbcs“-Schema: API 25+ |
PlayReady SL2000 | JA | Android TV, nur „cenc“-Schema |
Löschschlüssel | JA | API 21+, nur "cenc"-Schema |
Live-Wiedergabe | ||
Regelmäßige Livewiedergabe | JA | |
CMAF-Live-Wiedergabe 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.3.1")
Groovig
implementation "androidx.media3:media3-exoplayer-dash:1.3.1"
Anschließend kannst du einen 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 der URI nicht mit .mpd
endet, können Sie 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
Für weitere Anpassungsoptionen kannst du ein DashMediaSource
erstellen und es direkt an den Player übergeben, anstatt an eine 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
Sie können das aktuelle Manifest durch Aufrufen von Player.getCurrentManifest
abrufen.
Für DASH sollten Sie das zurückgegebene Objekt in DashManifest
umwandeln. Der onTimelineChanged
-Callback von Player.Listener
wird immer dann aufgerufen, wenn das Manifest geladen wird. Das ist einmal bei On-Demand-Inhalten und eventuell mehrmals bei Liveinhalten der Fall. Das folgende Code-Snippet zeigt, was eine App 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
ExoPlayer bietet Ihnen mehrere Möglichkeiten, die Wiedergabe an die Anforderungen Ihrer App anzupassen. Beispiele finden Sie auf der Seite „Anpassen“.