mirror of
https://github.com/nextcloud/talk-android
synced 2025-06-19 03:29:28 +01:00
Merge pull request #5060 from nextcloud/backport/5053/stable-21.1
[stable-21.1] Better null and error handling when playing voice messages
This commit is contained in:
commit
d1b3e7cb4d
@ -183,19 +183,26 @@ class MediaPlayerManager : LifecycleAwareManager {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mediaPlayer != null && mediaPlayer?.isPlaying == true) {
|
mediaPlayer?.let { player ->
|
||||||
val pos = mediaPlayer!!.currentPosition
|
try {
|
||||||
|
if (!player.isPlaying) return@let
|
||||||
|
} catch (e: IllegalStateException) {
|
||||||
|
Log.e(TAG, "Seekbar updated during an improper state: $e")
|
||||||
|
return@let
|
||||||
|
}
|
||||||
|
|
||||||
|
val pos = player.currentPosition
|
||||||
mediaPlayerPosition = pos
|
mediaPlayerPosition = pos
|
||||||
val progress = (pos.toFloat() / mediaPlayerDuration) * DIVIDER
|
val progress = (pos.toFloat() / mediaPlayerDuration) * DIVIDER
|
||||||
val progressI = ceil(progress).toInt()
|
val progressI = ceil(progress).toInt()
|
||||||
val seconds = (pos / ONE_SEC)
|
val seconds = (pos / ONE_SEC)
|
||||||
_mediaPlayerSeekBarPosition.emit(progressI)
|
_mediaPlayerSeekBarPosition.emit(progressI)
|
||||||
currentCycledMessage?.let {
|
currentCycledMessage?.let { msg ->
|
||||||
it.isPlayingVoiceMessage = true
|
msg.isPlayingVoiceMessage = true
|
||||||
it.voiceMessageSeekbarProgress = progressI
|
msg.voiceMessageSeekbarProgress = progressI
|
||||||
it.voiceMessagePlayedSeconds = seconds
|
msg.voiceMessagePlayedSeconds = seconds
|
||||||
if (progressI >= IS_PLAYED_CUTOFF) it.wasPlayedVoiceMessage = true
|
if (progressI >= IS_PLAYED_CUTOFF) msg.wasPlayedVoiceMessage = true
|
||||||
_mediaPlayerSeekBarPositionMsg.emit(it)
|
_mediaPlayerSeekBarPositionMsg.emit(msg)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
DO NOT TOUCH; GENERATED BY DRONE
|
DO NOT TOUCH; GENERATED BY DRONE
|
||||||
<span class="mdl-layout-title">Lint Report: 10 errors and 99 warnings</span>
|
<span class="mdl-layout-title">Lint Report: 10 errors and 100 warnings</span>
|
||||||
|
Loading…
Reference in New Issue
Block a user