update playlist playtime

This commit is contained in:
Christian Schabesberger 2024-09-04 15:13:21 +02:00
parent a2e9675906
commit 3eabb537f7
3 changed files with 37 additions and 6 deletions

View file

@ -36,6 +36,7 @@ data class VideoPlayerUIState(
val isLoading: Boolean,
val durationInMs: Long,
val playbackPositionInMs: Long,
val playbackPositionInPlaylistS: Int,
val fastSeekSeconds: Int,
val soundVolume: Float,
val brightness: Float?, // when null use system value
@ -58,6 +59,7 @@ data class VideoPlayerUIState(
bufferedPercentage = 0f,
isLoading = true,
durationInMs = 0,
playbackPositionInPlaylistS = 0,
playbackPositionInMs = 0,
fastSeekSeconds = 0,
soundVolume = 0f,
@ -78,6 +80,7 @@ data class VideoPlayerUIState(
bufferedPercentage = 0.5f,
isLoading = false,
durationInMs = 420,
playbackPositionInPlaylistS = 5039,
playbackPositionInMs = 69,
fastSeekSeconds = 10,
soundVolume = 0.5f,

View file

@ -30,8 +30,6 @@ import androidx.core.content.ContextCompat.getSystemService
import androidx.lifecycle.AndroidViewModel
import androidx.lifecycle.SavedStateHandle
import androidx.lifecycle.viewModelScope
import androidx.media3.common.MediaItem
import androidx.media3.common.MediaMetadata
import androidx.media3.common.Player
import dagger.hilt.android.lifecycle.HiltViewModel
import kotlinx.coroutines.Job
@ -42,7 +40,6 @@ import kotlinx.coroutines.flow.SharedFlow
import kotlinx.coroutines.flow.asSharedFlow
import javax.inject.Inject
import kotlinx.coroutines.flow.asStateFlow
import kotlinx.coroutines.flow.collect
import kotlinx.coroutines.flow.update
import kotlinx.coroutines.launch
import net.newpipe.newplayer.Chapter
@ -73,6 +70,7 @@ class VideoPlayerViewModelImpl @Inject constructor(
private var uiVisibilityJob: Job? = null
private var progressUpdaterJob: Job? = null
private var playlistProgressUpdatrJob: Job? = null
// this is necesary to restore the embedded view UI configuration when returning from fullscreen
private var embeddedUiConfig: EmbeddedUiConfig? = null
@ -295,7 +293,6 @@ class VideoPlayerViewModelImpl @Inject constructor(
delay(1000)
}
}
}
private fun updateProgressOnce() {
@ -310,7 +307,33 @@ class VideoPlayerViewModelImpl @Inject constructor(
seekerPosition = progressPercentage,
durationInMs = duration,
playbackPositionInMs = progress,
bufferedPercentage = bufferedPercentage
bufferedPercentage = bufferedPercentage,
)
}
}
private fun resetPlaylistProgressUpdaterJob() {
playlistProgressUpdatrJob?.cancel()
playlistProgressUpdatrJob = viewModelScope.launch {
while (true) {
updateProgressInPlaylistOnce()
delay(1000)
}
}
}
private fun updateProgressInPlaylistOnce() {
var progress = 0
val currentlyPlaying = uiState.value.currentlyPlaying.uniqueId
for (item in uiState.value.playList) {
if (item.uniqueId == currentlyPlaying)
break;
progress += item.lengthInS
}
progress += ((newPlayer?.currentPosition ?: 0) / 1000).toInt()
mutableUiState.update {
it.copy(
playbackPositionInPlaylistS = progress
)
}
}
@ -396,6 +419,7 @@ class VideoPlayerViewModelImpl @Inject constructor(
}
override fun openStreamSelection(selectChapter: Boolean, embeddedUiConfig: EmbeddedUiConfig) {
resetPlaylistProgressUpdaterJob()
uiVisibilityJob?.cancel()
if (!uiState.value.uiMode.fullscreen) {
this.embeddedUiConfig = embeddedUiConfig
@ -407,6 +431,7 @@ class VideoPlayerViewModelImpl @Inject constructor(
}
override fun closeStreamSelection() {
playlistProgressUpdatrJob?.cancel()
updateUiMode(uiState.value.uiMode.getUiHiddenState())
}

View file

@ -69,8 +69,11 @@ fun StreamSelectTopBar(
val locale = getLocale()!!
val duration = getPlaylistDurationInS(uiState.playList).toLong() * 1000
val durationString = getTimeStringFromMs(timeSpanInMs = duration, locale)
val playbackPositionString = getTimeStringFromMs(
timeSpanInMs = uiState.playbackPositionInPlaylistS.toLong() * 1000, locale = locale
)
Text(
text = "00:00/$durationString",
text = "$playbackPositionString/$durationString",
maxLines = 1,
overflow = TextOverflow.Ellipsis
)