Mô hình hàng đợi trong tính năng Truyền khác với mô hình hàng đợi trong MediaSession
.
Thư viện Cast Connect không hỗ trợ việc đọc hàng đợi do MediaSession
cung cấp.
Xử lý việc tải hàng đợi và thiết lập thông tin hàng đợi
Quá trình tải hàng đợi được thực hiện giống như cách tải các mục đơn lẻ (thông qua việc bắt đầu hoạt động bằng một ý định). Bạn cần sử dụng thư viện ứng dụng của chúng tôi để phân tích cú pháp ý định thành MediaLoadRequestData
.
Trường MediaQueueData
chứa thông tin về hàng đợi cần tải.
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(...); } }
Thay đổi hàng đợi
Khi có thay đổi đối với hàng đợi (chẳng hạn như từ queueInsert()
), bạn có thể sử dụng MediaQueueManager
để cập nhật hàng đợi. Nếu bạn đang tạo các mục hàng đợi mới, hãy nhớ đặt mã mục bằng cách gọi setItemId()
trên trình tạo bằng MediaQueueManager.autoGenerateItemId()
để tạo mã mục. Các mục trong hàng đợi được tải thông qua setDataFromLoad()
đã được đặt mã mặt hàng.
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();
Các ứng dụng Android TV cũng xử lý lệnh gọi lại onQueueUpdate()
để hỗ trợ chuyển đến các mục trong hàng đợi và bỏ qua mục tiếp theo/trước đó:
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());
Xử lý Điều khiển truyền tải liên quan đến hàng đợi
Bạn cũng có thể muốn triển khai các lệnh gọi lại kiểm soát quá trình truyền tải liên quan đến hàng đợi, chẳng hạn như onSkipToNext()
, onSkipToPrevious()
hoặc 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());