डैश

ExoPlayer, कई कंटेनर फ़ॉर्मैट वाले DASH का इस्तेमाल करता है. मीडिया स्ट्रीम इसका मतलब है कि वीडियो, ऑडियो, और टेक्स्ट को अलग-अलग DASH मेनिफ़ेस्ट में AdaptationSet एलिमेंट (CEA-608 एक अपवाद है) नीचे दी गई टेबल में बताया गया है). शामिल ऑडियो और वीडियो सैंपल फ़ॉर्मैट में भी इस्तेमाल किया जा सकता है (इसे देखें ज़्यादा जानकारी के लिए, फ़ॉर्मैट का सैंपल सेक्शन देखें).

सुविधा इनकी अनुमति है टिप्पणियां
कंटेनर
एफ़एमपी4 हां सिर्फ़ डीमक्स स्ट्रीम
WebM हां सिर्फ़ डीमक्स स्ट्रीम
मैट्रोस्का हां सिर्फ़ डीमक्स स्ट्रीम
एमपीईजी-टीएस नहीं सहायता की कोई योजना नहीं है
सबटाइटल/सबटाइटल
टीटीएमएल हां रॉ या ISO/IEC 14496-30 के अनुसार FMP4 में एम्बेड किया गया हो
WebVTT हां रॉ या ISO/IEC 14496-30 के अनुसार FMP4 में एम्बेड किया गया हो
सीईए-608 हां SCTE सुलभता डिस्क्रिप्टर का इस्तेमाल करके सिग्नल दिए जाने पर, FMP4 में एम्बेड किया गया
CEA-708 हां SCTE सुलभता डिस्क्रिप्टर का इस्तेमाल करके सिग्नल दिए जाने पर, FMP4 में एम्बेड किया गया
मेटाडेटा
ईएमएसजी मेटाडेटा हां FMP4 में एम्बेड किया गया
कॉन्टेंट की सुरक्षा
वाइडवाइन हां "सेंक" स्कीम: एपीआई 19+; "सीबीसी" स्कीम: एपीआई 25+
प्लेरेडी SL2000 हां Android TV, "सेंसर" सिर्फ़ स्कीम
क्लियरकी हां एपीआई 21+, "सेंस" सिर्फ़ स्कीम
लाइव वीडियो चलाना
नियमित तौर पर लाइव वीडियो चलाना हां
CMAF की मदद से लाइव स्ट्रीम करने के लिए, इंतज़ार का समय बहुत कम रखना हां
कॉमन मीडिया क्लाइंट डेटा (सीएमसीडी) हां इंटिग्रेशन गाइड

MediaItem का इस्तेमाल किया जा रहा है

DASH स्ट्रीम चलाने के लिए, आपको DASH मॉड्यूल पर निर्भर होना होगा.

Kotlin

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

ग्रूवी

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

इसके बाद, डैश एमपीडी यूआरआई के लिए MediaItem बनाया जा सकता है और उसे प्लेयर को दिया जा सकता है.

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

अगर आपका यूआरआई .mpd पर खत्म नहीं होता है, तो आप MimeTypes.APPLICATION_MPD को पास कर सकते हैं MediaItem.Builder के setMimeType तक को साफ़ तौर पर यह बताने के लिए कि कॉन्टेंट.

ExoPlayer, इस मेनिफ़ेस्ट करती है.

DashMediaSource का इस्तेमाल करना

पसंद के मुताबिक बनाने के ज़्यादा विकल्पों के लिए, DashMediaSource बनाएं और उसे पास करें 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();

मेनिफ़ेस्ट को ऐक्सेस करना

Player.getCurrentManifest पर कॉल करके, मौजूदा मेनिफ़ेस्ट को वापस लाया जा सकता है. DASH के लिए, आपको लौटाए गए ऑब्जेक्ट को DashManifest पर कास्ट करना चाहिए. कॉन्टेंट बनाने Player.Listener के onTimelineChanged कॉलबैक को कभी भी कॉल किया जाता है मेनिफ़ेस्ट लोड हो जाता है. मांग पर उपलब्ध कॉन्टेंट के लिए यह कार्रवाई एक बार होगी और कई बार लाइव कॉन्टेंट बनाने के लिए. नीचे दिया गया कोड स्निपेट दिखाता है कि कोई ऐप्लिकेशन जब भी मेनिफ़ेस्ट लोड होता है, तो कुछ काम किया जा सकता है.

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

प्लेबैक को अपनी पसंद के मुताबिक बनाया जा रहा है

ExoPlayer पर वीडियो चलाने का अनुभव बेहतर बनाने के लिए, इसमें आपको कई तरीके मिलते हैं की ज़रूरतों को पूरा करता है. उदाहरण के लिए, कस्टमाइज़ेशन पेज देखें.