يختلف نموذج "قائمة المحتوى التالي" في Cast عن ذلك في
MediaSession
.
لا تتيح مكتبة Cast Connect قراءة قائمة المحتوى التالي المقدَّمة من
MediaSession
.
التعامل مع تحميل "القائمة الانتظار" وضبط معلومات "القائمة الانتظار"
يتم تحميل "قائمة الانتظار" بالطريقة نفسها التي يتم بها تحميل العناصر الفردية (من خلال بدء
النشاط باستخدام نية). عليك استخدام مكتبة العميل لتحليل النية
إلى
MediaLoadRequestData
.
يحتوي الحقل
MediaQueueData
على معلومات "القائمة الانتظار" المطلوب تحميلها.
fun handleCastLoad(requestData: MediaLoadRequestData?) { if (requestData.getQueueData()) { // If MediaQueueData is specified, this is a queue load request. myPlayer.load( requestData.getQueueData().getItems().get(0)) // Set media status. castReceiverContext.getMediaManager() .setDataFromLoad(requestData) // This clears all status overrides. // The queue information is updated with // the MediaQueueData in the request. ... mediaSession.setPlaybackState(...) } }
private void handleCastLoad(MediaLoadRequestData requestData) { if (requestData.getQueueData()) { // If MediaQueueData is specified, this is a queue load request. myPlayer.load( requestData.getQueueData().getItems().get(0)); // Set media status. castReceiverContext.getMediaManager() .setDataFromLoad(requestData) // This clears all status overrides. // The queue information is updated with // the MediaQueueData in the request. ...; mediaSession.setPlaybackState(...); } }
تغيير قائمة المحتوى التالي
عند إجراء تغييرات على قائمة الانتظار (مثلاً من queueInsert()
)، يمكنك استخدام
MediaQueueManager
لتحديث قائمة الانتظار. إذا كنت بصدد إنشاء عناصر جديدة في "قائمة المحتوى التالي"، احرص على ضبط
معرّف العنصر من خلال استدعاء
setItemId()
في أداة الإنشاء باستخدام
MediaQueueManager.autoGenerateItemId()
لإنشاء معرّف العنصر. إنّ العناصر في قائمة المحتوى التالي التي تم تحميلها من خلال
setDataFromLoad()
سبق ضبط معرّفاتها.
val mediaManager: MediaManager = castReceiverContext.getMediaManager() val mediaQueueManager = mediaManager.getMediaQueueManager() mediaQueueManager.getQueueItems().add( /* position= */index, mediaQueueItem) mediaManager.broadcastMediaStatus()
MediaManager mediaManager = castReceiverContext.getMediaManager(); MediaQueueManager mediaQueueManager = mediaManager.getMediaQueueManager(); mediaQueueManager.getQueueItems().add(/* position= */ index, mediaQueueItem); mediaManager.broadcastMediaStatus();
تتعامل تطبيقات Android TV أيضًا مع طلبات إعادة الاتصال
onQueueUpdate()
للسماح بالانتقال إلى عناصر "قائمة المحتوى التالي" وتخطّي المحتوى التالي/السابق:
class MyMediaCommandCallback : MediaCommandCallback() { override fun onQueueUpdate( queueUpdateRequestData: QueueUpdateRequestData ): Task{ ... var newItemId = MediaQueueItem.INVALID_ITEM_ID if (queueUpdateRequestData.getJump() != null) { newItemId = myGetRelativeItemId(queueUpdateRequestData.getJump()) } else if (queueUpdateRequestData.getCurrentItemId() != null) { newItemId = queueUpdateRequestData.getCurrentItemId() } if (newItemId != MediaQueueItem.INVALID_ITEM_ID) { castReceiverContext.getMediaManager().getMediaQueueManager() .setCurrentItemId(newItemId) castReceiverContext.getMediaManager().broadcastMediaStatus() } } } val mediaManager = CastReceiverContext.getInstance().getMediaQueueManager() mediaManager.setMediaCommandCallback(MyMediaCommandCallback())
public class MyMediaCommandCallback extends MediaCommandCallback { @Override public TaskonQueueUpdate( QueueUpdateRequestData queueUpdateRequestData) { ... int newItemId = MediaQueueItem.INVALID_ITEM_ID; if (queueUpdateRequestData.getJump() != null) { newItemId = myGetRelativeItemId(queueUpdateRequestData.getJump()); } else if (queueUpdateRequestData.getCurrentItemId() != null) { newItemId = queueUpdateRequestData.getCurrentItemId(); } if (newItemId != MediaQueueItem.INVALID_ITEM_ID) { castReceiverContext.getMediaManager().getMediaQueueManager() .setCurrentItemId(newItemId); castReceiverContext.getMediaManager().broadcastMediaStatus(); } } MediaManager mediaManager = CastReceiverContext.getInstance().getMediaManager(); mediaManager.setMediaCommandCallback(new MyMediaCommandCallback());
التعامل مع التحكّم في النقل المرتبط بالانتظار
قد تحتاج أيضًا إلى تنفيذ عمليات استدعاء التحكّم في النقل ذات الصلة بالانتظار، مثل
onSkipToNext()
،
onSkipToPrevious()
،
أو
onSkipToQueueItem()
.
class MyMediaSessionCallback : MediaSessionCompat.Callback() { override fun onSkipToNext() { // Skip to next item in queue ... } override fun onSkipToPrevious() { // Skip to previous item in queue ... } override fun onSkipToQueueItem(pos: Long) { // Skip to specified queue item ... } ... } mediaSession.setCallback(MyMediaSessionCallback())
public class MyMediaSessionCallback extends MediaSessionCompat.Callback { @Override public void onSkipToNext() { // Skip to next item in queue ... } @Override public void onSkipToPrevious() { // Skip to previous item in queue ... } @Override public void onSkipToQueueItem (long pos) { // Skip to specified queue item ... } ... } mediaSession.setCallback(new MyMediaSessionCallback());