ExoPlayer, DASH के साथ-साथ कई कंटेनर फ़ॉर्मैट के साथ काम करता है. मीडिया स्ट्रीम को डीमक्स किया जाना चाहिए. इसका मतलब है कि वीडियो, ऑडियो, और टेक्स्ट को DASH मेनिफ़ेस्ट में अलग-अलग AdaptationSet
एलिमेंट में तय किया जाना चाहिए. हालांकि, CEA-608 एक अपवाद है, जैसा कि यहां दी गई टेबल में बताया गया है. इसमें शामिल ऑडियो और वीडियो सैंपल के फ़ॉर्मैट भी काम करने चाहिए. ज़्यादा जानकारी के लिए, सैंपल फ़ॉर्मैट सेक्शन देखें.
सुविधा | इनकी अनुमति है | टिप्पणियां |
---|---|---|
कंटेनर | ||
FMP4 | हां | सिर्फ़ डीमक्स की गई स्ट्रीम |
WebM | हां | सिर्फ़ डीमक्स की गई स्ट्रीम |
Matroska | हां | सिर्फ़ डीमक्स की गई स्ट्रीम |
MPEG-TS | नहीं | सहायता उपलब्ध नहीं है |
सबटाइटल / कैप्शन | ||
TTML | हां | ISO/IEC 14496-30 के मुताबिक, रॉ या FMP4 में एम्बेड किया गया |
WebVTT | हां | ISO/IEC 14496-30 के मुताबिक, रॉ या FMP4 में एम्बेड किया गया |
CEA-608 | हां | SCTE Accessibility descriptors का इस्तेमाल करके सिग्नल देने पर, FMP4 में एम्बेड किया गया |
CEA-708 | हां | SCTE Accessibility descriptors का इस्तेमाल करके सिग्नल देने पर, FMP4 में एम्बेड किया गया |
मेटाडेटा | ||
ईएमएसजी मेटाडेटा | हां | FMP4 में एम्बेड किया गया |
कॉन्टेंट की सुरक्षा | ||
वाइडवाइन | हां | "cenc" स्कीम: API 19 या इसके बाद का वर्शन; "cbcs" स्कीम: API 25 या इसके बाद का वर्शन |
PlayReady SL2000 | हां | Android TV, सिर्फ़ "cenc" स्कीम |
ClearKey | हां | एपीआई 21 और इससे ऊपर के वर्शन के लिए, सिर्फ़ "cenc" स्कीम |
विज्ञापन शामिल करना | ||
एक से ज़्यादा अवधि वाला प्लेबैक | हां | |
सर्वर की मदद से विज्ञापन डालने की सुविधा (xlinks) | नहीं | |
IMA सर्वर-साइड और क्लाइंट-साइड विज्ञापन | हां | विज्ञापन डालने के बारे में गाइड |
लाइव स्ट्रीम को फिर से चलाना | ||
लाइव स्ट्रीम को सामान्य तरीके से चलाना | हां | |
अल्ट्रा लो-लेटेंसी सीएमएएफ़ लाइव स्ट्रीम चलाना | हां | |
कॉमन मीडिया क्लाइंट डेटा (सीएमसीडी) | हां | CMCD इंटिग्रेशन गाइड |
MediaItem का इस्तेमाल करना
DASH स्ट्रीम चलाने के लिए, आपको DASH मॉड्यूल पर निर्भर रहना होगा.
Kotlin
implementation("androidx.media3:media3-exoplayer-dash:1.8.0")
Groovy
implementation "androidx.media3:media3-exoplayer-dash:1.8.0"
इसके बाद, DASH MPD यूआरआई के लिए 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
से खत्म नहीं होता है, तो कॉन्टेंट का टाइप साफ़ तौर पर बताने के लिए, MediaItem.Builder
के setMimeType
को MimeTypes.APPLICATION_MPD
पास किया जा सकता है.
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, आपके ऐप्लिकेशन की ज़रूरतों के हिसाब से वीडियो चलाने की सुविधा को बेहतर बनाने के कई तरीके उपलब्ध कराता है. उदाहरणों के लिए, कस्टमाइज़ेशन पेज देखें.