يتيح ExoPlayer استخدام DASH مع تنسيقات حاويات متعدّدة. يجب فصل دفقات الوسائط، ما يعني أنّه يجب تحديد الفيديو والصوت والنص في عناصر AdaptationSet منفصلة في بيان DASH (يُستثنى من ذلك CEA-608 كما هو موضّح في الجدول أدناه). يجب أيضًا أن تكون تنسيقات نماذج الصوت والفيديو المضمّنة متوافقة (راجِع قسم
تنسيقات النماذج لمزيد من التفاصيل).
| الميزة | متاح | التعليقات |
|---|---|---|
| الحاويات | ||
| FMP4 | نعم | الدفقات المفصولة فقط |
| WebM | نعم | الدفقات المفصولة فقط |
| Matroska | نعم | الدفقات المفصولة فقط |
| MPEG-TS | لا | لا نخطط لإتاحة هذه الميزة |
| الترجمة والشرح / الترجمة | ||
| TTML | نعم | تنسيق raw أو مضمّنة في FMP4 وفقًا للمعيار ISO/IEC 14496-30 |
| WebVTT | نعم | تنسيق raw أو مضمّنة في FMP4 وفقًا للمعيار ISO/IEC 14496-30 |
| CEA-608 | نعم | مضمّنة في FMP4 عند الإشارة إليها باستخدام واصفات إمكانية الوصول إلى SCTE |
| CEA-708 | نعم | مضمّنة في FMP4 عند الإشارة إليها باستخدام واصفات إمكانية الوصول إلى SCTE |
| البيانات الوصفية | ||
| البيانات الوصفية لـ EMSG | نعم | مضمّنة في FMP4 |
| حماية المحتوى | ||
| Widevine | نعم | نظام "cenc": الإصدار 19 من واجهة برمجة التطبيقات والإصدارات الأحدث، ونظام "cbcs": الإصدار 25 من واجهة برمجة التطبيقات والإصدارات الأحدث |
| PlayReady SL2000 | نعم | Android TV، ونظام "cenc" فقط |
| ClearKey | نعم | الإصدار 21 من واجهة برمجة التطبيقات والإصدارات الأحدث، ونظام "cenc" فقط |
| إدراج الإعلانات | ||
| تشغيل المحتوى المتعدّد الفترات | نعم | |
| إدراج الإعلانات الموجّه من الخادم (xlinks) | لا | |
| إعلانات IMA من جهة الخادم ومن جهة العميل | نعم | دليل إدراج الإعلانات |
| تشغيل البث المباشر | ||
| تشغيل البث المباشر العادي | نعم | |
| تشغيل البث المباشر بتنسيق CMAF مع وقت استجابة سريع جدًا | نعم | |
| بيانات عميل الوسائط الشائعة (CMCD) | نعم | دليل التكامل مع CMCD |
استخدام MediaItem
لتشغيل دفق DASH، عليك الاعتماد على وحدة DASH.
Kotlin
implementation("androidx.media3:media3-exoplayer-dash:1.10.0")
أنيق
implementation "androidx.media3:media3-exoplayer-dash:1.10.0"
يمكنك بعد ذلك إنشاء MediaItem لمعرّف URI لملف MPD بتنسيق DASH وتمريره إلى المشغّل.
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 بـ .mpd، يمكنك تمرير MimeTypes.APPLICATION_MPD إلى setMimeType في MediaItem.Builder للإشارة بوضوح إلى نوع المحتوى.
سيعدّل 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. يتم أيضًا استدعاء دالة ردّ الاتصال onTimelineChanged في Player.Listener كلّما تم تحميل البيان. سيحدث ذلك مرة واحدة للمحتوى عند الطلب، وقد يحدث عدة مرات للمحتوى المباشر. يوضّح مقتطف الرمز التالي كيف يمكن لتطبيق تنفيذ إجراء ما كلّما تم تحميل البيان.
Kotlin
player.addListener( object : Player.Listener { override fun onTimelineChanged( timeline: Timeline, @Player.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 طرقًا متعدّدة لتخصيص تجربة التشغيل بما يتناسب مع احتياجات تطبيقك. راجِع صفحة التخصيص للاطّلاع على أمثلة.