KONTROL ET

ExoPlayer, birden çok kapsayıcı biçimiyle DASH'i destekler. Medya akışları: demuxed; yani video, ses ve metnin farklı DASH manifestindeki AdaptationSet öğeleri (CEA-608, ) kullanılabilir. İçerikteki ses ve video örnek biçimleri, (bkz. örnek biçimler bölümüne bakın).

Özellik Destekleniyor Yorumlar
Kapsayıcılar
FMP4 EVET Yalnızca devre dışı bırakılan akışlar
WebM EVET Yalnızca devre dışı bırakılan akışlar
Matroska EVET Yalnızca devre dışı bırakılan akışlar
MPEG-TS HAYIR Planlanmış destek yok
Altyazılar
TTML EVET ISO/IEC 14496-30'a uygun olarak ham veya FMP4'e yerleştirilmiştir
WebVTT EVET ISO/IEC 14496-30'a uygun olarak ham veya FMP4'e yerleştirilmiştir
CEA-608 EVET SCTE erişilebilirlik tanımlayıcıları kullanılarak sinyal verildiğinde FMP4'e yerleştirilir.
CEA-708 EVET SCTE erişilebilirlik tanımlayıcıları kullanılarak sinyal verildiğinde FMP4'e yerleştirilir.
Meta veri
EMSG meta verileri EVET FMP4'e yerleştirilmiş
İçerik koruması
Widevine EVET "cenc" schema: API 19+; "Cbcs" şema: API 25+
PlayReady SL2000 EVET Android TV, "cenc" yalnızca şema
Anahtarı Temizle EVET API 21+, "cenc" yalnızca şema
Canlı oynatma
Düzenli canlı oynatma EVET
Ultra düşük gecikmeli CMAF canlı oynatma EVET
Ortak Medya İstemci Verileri (CMCD) EVET Entegrasyon Kılavuzu

MediaItem'i Kullanma

DASH akışı oynatmak için DASH modülüne güvenmeniz gerekir.

Kotlin

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

Eski

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

Daha sonra, DASH MPD URI'si için bir MediaItem oluşturabilir ve bunu oynatıcıya aktarabilirsiniz.

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();

URI'niz .mpd ile bitmiyorsa MimeTypes.APPLICATION_MPD parametresini iletebilirsiniz to setMimeType/MediaItem.Builder içerik.

ExoPlayer, 2022'de bu oyunda tanımlanan temsiller arasında otomatik olarak manifestosunu oluşturduk.

DashMediaSource'u Kullanma

Daha fazla özelleştirme seçeneği için DashMediaSource oluşturup iletebilirsiniz doğrudan oynatıcıya gönderilir.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();

Manifest dosyasına erişme

Player.getCurrentManifest öğesini çağırarak geçerli manifesti alabilirsiniz. DASH için döndürülen nesneyi DashManifest öğesine yayınlamanız gerekir. İlgili içeriği oluşturmak için kullanılan Player.Listener için onTimelineChanged geri çağırması her zaman manifest yüklendi. Bu, seç-izle içeriklerde bir kez gerçekleşir ve bunu, canlı içeriklerde de yapabilirsiniz. Aşağıdaki kod snippet'i bir uygulamanın, manifest dosyası her yüklendiğinde bir işlem yapabilir.

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.
        }
      }
    });

Oynatmayı özelleştirme

ExoPlayer, oynatma deneyimini kendi tercihinize göre uyarlamanız için çeşitli yöntemler sunar. iyi bir fikir olabilir. Örnekler için Özelleştirme sayfasına göz atın.