mirror of
https://github.com/recloudstream/cloudstream.git
synced 2024-08-15 01:53:11 +00:00
More robust player release (#601)
This commit is contained in:
parent
8fe34d3d2a
commit
a5450e5da2
2 changed files with 12 additions and 4 deletions
|
@ -517,6 +517,7 @@ abstract class AbstractPlayerFragment(
|
|||
canEnterPipMode = false
|
||||
mMediaSession?.release()
|
||||
mMediaSession = null
|
||||
playerView?.player = null
|
||||
SubtitlesFragment.applyStyleEvent -= ::onSubStyleChanged
|
||||
|
||||
keepScreenOn(false)
|
||||
|
|
|
@ -51,6 +51,7 @@ import com.lagradost.cloudstream3.AcraApplication.Companion.getKey
|
|||
import com.lagradost.cloudstream3.AcraApplication.Companion.setKey
|
||||
import com.lagradost.cloudstream3.USER_AGENT
|
||||
import com.lagradost.cloudstream3.app
|
||||
import com.lagradost.cloudstream3.mvvm.debugAssert
|
||||
import com.lagradost.cloudstream3.mvvm.logError
|
||||
import com.lagradost.cloudstream3.mvvm.normalSafeApiCall
|
||||
import com.lagradost.cloudstream3.ui.subtitles.SaveCaptionStyle
|
||||
|
@ -85,6 +86,12 @@ const val toleranceAfterUs = 300_000L
|
|||
class CS3IPlayer : IPlayer {
|
||||
private var isPlaying = false
|
||||
private var exoPlayer: ExoPlayer? = null
|
||||
set(value) {
|
||||
// If the old value is not null then the player has not been properly released.
|
||||
debugAssert({ field != null && value != null }, { "Previous player instance should be released!" })
|
||||
field = value
|
||||
}
|
||||
|
||||
var cacheSize = 0L
|
||||
var simpleCacheSize = 0L
|
||||
var videoBufferMs = 0L
|
||||
|
@ -682,13 +689,13 @@ class CS3IPlayer : IPlayer {
|
|||
metadataRendererOutput
|
||||
).map {
|
||||
if (it is TextRenderer) {
|
||||
currentTextRenderer = CustomTextRenderer(
|
||||
val currentTextRenderer = CustomTextRenderer(
|
||||
subtitleOffset,
|
||||
textRendererOutput,
|
||||
eventHandler.looper,
|
||||
CustomSubtitleDecoderFactory()
|
||||
)
|
||||
currentTextRenderer!!
|
||||
).also { this.currentTextRenderer = it }
|
||||
currentTextRenderer
|
||||
} else it
|
||||
}.toTypedArray()
|
||||
}
|
||||
|
@ -1323,7 +1330,7 @@ class CS3IPlayer : IPlayer {
|
|||
override fun reloadPlayer(context: Context) {
|
||||
Log.i(TAG, "reloadPlayer")
|
||||
|
||||
exoPlayer?.release()
|
||||
releasePlayer(false)
|
||||
currentLink?.let {
|
||||
loadOnlinePlayer(context, it)
|
||||
} ?: currentDownloadedFile?.let {
|
||||
|
|
Loading…
Reference in a new issue