DASH

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 demuxierte 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 sie 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
Löschschlüssel 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.0")

Cool

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

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“.