fix the playing queue

This commit is contained in:
Bnyro 2022-09-23 14:12:41 +02:00
parent d1351e0f67
commit 845b6fe2ad
3 changed files with 16 additions and 19 deletions

View File

@ -78,7 +78,7 @@ class VideoOptionsBottomSheet(
shareDialog.show(parentFragmentManager, ShareDialog::class.java.name)
}
context?.getString(R.string.play_next) -> {
PlayingQueue.playNext(videoId)
PlayingQueue.addAsNext(videoId)
}
context?.getString(R.string.add_to_queue) -> {
PlayingQueue.add(videoId)

View File

@ -40,7 +40,7 @@ class AutoPlayHelper(
if (relatedStreams == null || relatedStreams.isEmpty()) return null
var index = 0
var nextStreamId: String? = null
while (nextStreamId == null || PlayingQueue.containsBefore(nextStreamId)) {
while (nextStreamId == null || PlayingQueue.containsBeforeCurrent(nextStreamId)) {
nextStreamId = relatedStreams[index].url!!.toID()
if (index + 1 < relatedStreams.size) {
index += 1

View File

@ -4,17 +4,13 @@ object PlayingQueue {
private val queue = mutableListOf<String>()
private var currentVideoId: String? = null
fun clear() {
queue.clear()
}
fun add(videoId: String) {
if (currentVideoId == videoId) return
if (queue.contains(videoId)) queue.remove(videoId)
queue.add(videoId)
}
fun playNext(videoId: String) {
fun addAsNext(videoId: String) {
if (currentVideoId == videoId) return
if (queue.contains(videoId)) queue.remove(videoId)
queue.add(
@ -24,11 +20,10 @@ object PlayingQueue {
}
fun getNext(): String? {
val currentIndex = queue.indexOf(currentVideoId)
return if (currentIndex >= queue.size) {
return try {
queue[currentIndex() + 1]
} catch (e: Exception) {
null
} else {
queue[currentIndex + 1]
}
}
@ -41,18 +36,20 @@ object PlayingQueue {
return queue.indexOf(currentVideoId) > 0
}
fun contains(videoId: String): Boolean {
return queue.contains(videoId)
}
fun containsBefore(videoId: String): Boolean {
return queue.contains(videoId) && queue.indexOf(videoId) < queue.indexOf(currentVideoId)
}
fun updateCurrent(videoId: String) {
currentVideoId = videoId
queue.add(videoId)
}
fun isNotEmpty() = queue.isNotEmpty()
fun clear() = queue.clear()
fun currentIndex() = queue.indexOf(currentVideoId)
fun contains(videoId: String) = queue.contains(videoId)
fun containsBeforeCurrent(videoId: String): Boolean {
return queue.contains(videoId) && queue.indexOf(videoId) < currentIndex()
}
}