Mô hình hàng đợi trong Truyền khác với mô hình trong
MediaSession
.
Thư viện Cast Connect không hỗ trợ đọc hàng đợi do
MediaSession
.
Xử lý việc tải và đặt thông tin về hàng đợi
Việc tải hàng đợi được thực hiện giống như khi tải từng mục (thông qua việc bắt đầu
hoạt động có ý định). Bạn cần dùng thư viện ứng dụng để phân tích cú pháp ý định
thành một
MediaLoadRequestData
.
Chiến lược phát hành đĩa đơn
MediaQueueData
chứa thông tin hàng đợi cần được 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 mục hàng đợi mới, hãy nhớ đặt
mã mặt hàng bằng cách gọi
setItemId()
trên trình tạo bằng cách sử dụng
MediaQueueManager.autoGenerateItemId()
để tạo mã mặt hàng. Các mục trong hàng đợi được tải qua
setDataFromLoad()
đã đặt mã mặt hàng của họ.
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ý
onQueueUpdate()
lệnh gọi lại để hỗ trợ chuyển đến các mục 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ý biện pháp kiểm soát truyền tải liên quan đến hàng đợi
Bạn cũng nên triển khai các lệnh gọi lại kiểm soát phương tiện truyền tải liên quan đến hàng đợi, chẳng hạn như
dưới dạng
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());