DASH

ExoPlayer unterstützt DASH mit mehreren Containerformaten. Medienstreams müssen demultiplext werden, d. h. Video, Audio und Text müssen im DASH-Manifest in separaten AdaptationSet-Elementen definiert werden. 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 Roh 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 „cenc“-Schema
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.5.0")

Groovy

implementation "androidx.media3:media3-exoplayer-dash:1.5.0"

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 auch jedes Mal 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“.