mirror of
https://github.com/libre-tube/LibreTube.git
synced 2024-12-15 06:40:30 +05:30
cleanup
This commit is contained in:
parent
e876557368
commit
36246255c4
@ -23,11 +23,9 @@ import android.util.Log
|
|||||||
import android.view.LayoutInflater
|
import android.view.LayoutInflater
|
||||||
import android.view.View
|
import android.view.View
|
||||||
import android.view.ViewGroup
|
import android.view.ViewGroup
|
||||||
import android.view.accessibility.CaptioningManager
|
|
||||||
import android.widget.Toast
|
import android.widget.Toast
|
||||||
import androidx.constraintlayout.motion.widget.MotionLayout
|
import androidx.constraintlayout.motion.widget.MotionLayout
|
||||||
import androidx.constraintlayout.widget.ConstraintLayout
|
import androidx.constraintlayout.widget.ConstraintLayout
|
||||||
import androidx.core.content.ContextCompat
|
|
||||||
import androidx.core.net.toUri
|
import androidx.core.net.toUri
|
||||||
import androidx.core.os.bundleOf
|
import androidx.core.os.bundleOf
|
||||||
import androidx.core.view.isVisible
|
import androidx.core.view.isVisible
|
||||||
@ -48,7 +46,6 @@ import com.github.libretube.dialogs.AddtoPlaylistDialog
|
|||||||
import com.github.libretube.dialogs.DownloadDialog
|
import com.github.libretube.dialogs.DownloadDialog
|
||||||
import com.github.libretube.dialogs.ShareDialog
|
import com.github.libretube.dialogs.ShareDialog
|
||||||
import com.github.libretube.obj.ChapterSegment
|
import com.github.libretube.obj.ChapterSegment
|
||||||
import com.github.libretube.obj.PipedStream
|
|
||||||
import com.github.libretube.obj.Playlist
|
import com.github.libretube.obj.Playlist
|
||||||
import com.github.libretube.obj.Segment
|
import com.github.libretube.obj.Segment
|
||||||
import com.github.libretube.obj.Segments
|
import com.github.libretube.obj.Segments
|
||||||
@ -62,6 +59,7 @@ import com.github.libretube.util.BackgroundMode
|
|||||||
import com.github.libretube.util.ConnectionHelper
|
import com.github.libretube.util.ConnectionHelper
|
||||||
import com.github.libretube.util.CronetHelper
|
import com.github.libretube.util.CronetHelper
|
||||||
import com.github.libretube.util.DescriptionAdapter
|
import com.github.libretube.util.DescriptionAdapter
|
||||||
|
import com.github.libretube.util.PlayerHelper
|
||||||
import com.github.libretube.util.RetrofitInstance
|
import com.github.libretube.util.RetrofitInstance
|
||||||
import com.github.libretube.util.formatShort
|
import com.github.libretube.util.formatShort
|
||||||
import com.github.libretube.views.DoubleClickListener
|
import com.github.libretube.views.DoubleClickListener
|
||||||
@ -352,6 +350,60 @@ class PlayerFragment : Fragment() {
|
|||||||
isPlayerLocked = !isPlayerLocked
|
isPlayerLocked = !isPlayerLocked
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// set default playback speed
|
||||||
|
val playbackSpeed =
|
||||||
|
PreferenceHelper.getString(requireContext(), "playback_speed", "1F")!!
|
||||||
|
val playbackSpeeds = context?.resources?.getStringArray(R.array.playbackSpeed)!!
|
||||||
|
val playbackSpeedValues =
|
||||||
|
context?.resources?.getStringArray(R.array.playbackSpeedValues)!!
|
||||||
|
exoPlayer.setPlaybackSpeed(playbackSpeed.toFloat())
|
||||||
|
val speedIndex = playbackSpeedValues.indexOf(playbackSpeed)
|
||||||
|
playerBinding.speedText.text = playbackSpeeds[speedIndex]
|
||||||
|
|
||||||
|
// change playback speed button
|
||||||
|
playerBinding.speedText.setOnClickListener {
|
||||||
|
MaterialAlertDialogBuilder(requireContext())
|
||||||
|
.setTitle(R.string.change_playback_speed)
|
||||||
|
.setItems(playbackSpeeds) { _, index ->
|
||||||
|
// set the new playback speed
|
||||||
|
val newPlaybackSpeed = playbackSpeedValues[index].toFloat()
|
||||||
|
exoPlayer.setPlaybackSpeed(newPlaybackSpeed)
|
||||||
|
playerBinding.speedText.text = playbackSpeeds[index]
|
||||||
|
}
|
||||||
|
.show()
|
||||||
|
}
|
||||||
|
|
||||||
|
// repeat toggle button
|
||||||
|
playerBinding.repeatToggle.setOnClickListener {
|
||||||
|
if (exoPlayer.repeatMode == RepeatModeUtil.REPEAT_TOGGLE_MODE_ALL) {
|
||||||
|
// turn off repeat mode
|
||||||
|
exoPlayer.repeatMode = RepeatModeUtil.REPEAT_TOGGLE_MODE_NONE
|
||||||
|
playerBinding.repeatToggle.setColorFilter(Color.GRAY)
|
||||||
|
} else {
|
||||||
|
exoPlayer.repeatMode = RepeatModeUtil.REPEAT_TOGGLE_MODE_ALL
|
||||||
|
playerBinding.repeatToggle.setColorFilter(Color.WHITE)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// share button
|
||||||
|
binding.relPlayerShare.setOnClickListener {
|
||||||
|
val shareDialog = ShareDialog(videoId!!, false)
|
||||||
|
shareDialog.show(childFragmentManager, "ShareDialog")
|
||||||
|
}
|
||||||
|
|
||||||
|
binding.relPlayerBackground.setOnClickListener {
|
||||||
|
// pause the current player
|
||||||
|
exoPlayer.pause()
|
||||||
|
|
||||||
|
// start the background mode
|
||||||
|
BackgroundMode
|
||||||
|
.getInstance()
|
||||||
|
.playOnBackgroundMode(
|
||||||
|
requireContext(),
|
||||||
|
videoId!!
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
binding.playerScrollView.viewTreeObserver
|
binding.playerScrollView.viewTreeObserver
|
||||||
.addOnScrollChangedListener {
|
.addOnScrollChangedListener {
|
||||||
if (binding.playerScrollView.getChildAt(0).bottom
|
if (binding.playerScrollView.getChildAt(0).bottom
|
||||||
@ -745,7 +797,7 @@ class PlayerFragment : Fragment() {
|
|||||||
val useSystemCaptionStyle = PreferenceHelper.getBoolean(requireContext(), "system_caption_style", true)
|
val useSystemCaptionStyle = PreferenceHelper.getBoolean(requireContext(), "system_caption_style", true)
|
||||||
if (useSystemCaptionStyle) {
|
if (useSystemCaptionStyle) {
|
||||||
// set the subtitle style
|
// set the subtitle style
|
||||||
val captionStyle = getCaptionStyle()
|
val captionStyle = PlayerHelper.getCaptionStyle(requireContext())
|
||||||
exoPlayerView.subtitleView?.setApplyEmbeddedStyles(captionStyle == CaptionStyleCompat.DEFAULT)
|
exoPlayerView.subtitleView?.setApplyEmbeddedStyles(captionStyle == CaptionStyleCompat.DEFAULT)
|
||||||
exoPlayerView.subtitleView?.setStyle(captionStyle)
|
exoPlayerView.subtitleView?.setStyle(captionStyle)
|
||||||
}
|
}
|
||||||
@ -777,29 +829,6 @@ class PlayerFragment : Fragment() {
|
|||||||
initializeChapters()
|
initializeChapters()
|
||||||
}
|
}
|
||||||
|
|
||||||
// set default playback speed
|
|
||||||
val playbackSpeed =
|
|
||||||
PreferenceHelper.getString(requireContext(), "playback_speed", "1F")!!
|
|
||||||
val playbackSpeeds = context?.resources?.getStringArray(R.array.playbackSpeed)!!
|
|
||||||
val playbackSpeedValues =
|
|
||||||
context?.resources?.getStringArray(R.array.playbackSpeedValues)!!
|
|
||||||
exoPlayer.setPlaybackSpeed(playbackSpeed.toFloat())
|
|
||||||
val speedIndex = playbackSpeedValues.indexOf(playbackSpeed)
|
|
||||||
playerBinding.speedText.text = playbackSpeeds[speedIndex]
|
|
||||||
|
|
||||||
// change playback speed button
|
|
||||||
playerBinding.speedText.setOnClickListener {
|
|
||||||
MaterialAlertDialogBuilder(requireContext())
|
|
||||||
.setTitle(R.string.change_playback_speed)
|
|
||||||
.setItems(playbackSpeeds) { _, index ->
|
|
||||||
// set the new playback speed
|
|
||||||
val newPlaybackSpeed = playbackSpeedValues[index].toFloat()
|
|
||||||
exoPlayer.setPlaybackSpeed(newPlaybackSpeed)
|
|
||||||
playerBinding.speedText.text = playbackSpeeds[index]
|
|
||||||
}
|
|
||||||
.show()
|
|
||||||
}
|
|
||||||
|
|
||||||
// Listener for play and pause icon change
|
// Listener for play and pause icon change
|
||||||
exoPlayer.addListener(object : Player.Listener {
|
exoPlayer.addListener(object : Player.Listener {
|
||||||
override fun onIsPlayingChanged(isPlaying: Boolean) {
|
override fun onIsPlayingChanged(isPlaying: Boolean) {
|
||||||
@ -866,37 +895,6 @@ class PlayerFragment : Fragment() {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
// repeat toggle button
|
|
||||||
playerBinding.repeatToggle.setOnClickListener {
|
|
||||||
if (exoPlayer.repeatMode == RepeatModeUtil.REPEAT_TOGGLE_MODE_ALL) {
|
|
||||||
// turn off repeat mode
|
|
||||||
exoPlayer.repeatMode = RepeatModeUtil.REPEAT_TOGGLE_MODE_NONE
|
|
||||||
playerBinding.repeatToggle.setColorFilter(Color.GRAY)
|
|
||||||
} else {
|
|
||||||
exoPlayer.repeatMode = RepeatModeUtil.REPEAT_TOGGLE_MODE_ALL
|
|
||||||
playerBinding.repeatToggle.setColorFilter(Color.WHITE)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// share button
|
|
||||||
binding.relPlayerShare.setOnClickListener {
|
|
||||||
val shareDialog = ShareDialog(videoId!!, false)
|
|
||||||
shareDialog.show(childFragmentManager, "ShareDialog")
|
|
||||||
}
|
|
||||||
|
|
||||||
binding.relPlayerBackground.setOnClickListener {
|
|
||||||
// pause the current player
|
|
||||||
exoPlayer.pause()
|
|
||||||
|
|
||||||
// start the background mode
|
|
||||||
BackgroundMode
|
|
||||||
.getInstance()
|
|
||||||
.playOnBackgroundMode(
|
|
||||||
requireContext(),
|
|
||||||
videoId!!
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
// check if livestream
|
// check if livestream
|
||||||
if (response.duration!! > 0) {
|
if (response.duration!! > 0) {
|
||||||
// download clicked
|
// download clicked
|
||||||
@ -1206,7 +1204,7 @@ class PlayerFragment : Fragment() {
|
|||||||
exoPlayer.setMediaItem(mediaItem)
|
exoPlayer.setMediaItem(mediaItem)
|
||||||
} else {
|
} else {
|
||||||
val videoUri = videosUrlArray[which]
|
val videoUri = videosUrlArray[which]
|
||||||
val audioUrl = getMostBitRate(response.audioStreams!!)
|
val audioUrl = PlayerHelper.getMostBitRate(response.audioStreams!!)
|
||||||
setMediaSource(videoUri, audioUrl)
|
setMediaSource(videoUri, audioUrl)
|
||||||
}
|
}
|
||||||
exoPlayer.seekTo(lastPosition)
|
exoPlayer.seekTo(lastPosition)
|
||||||
@ -1233,7 +1231,7 @@ class PlayerFragment : Fragment() {
|
|||||||
// search for quality preference in the available stream sources
|
// search for quality preference in the available stream sources
|
||||||
if (pipedStream.contains(defRes)) {
|
if (pipedStream.contains(defRes)) {
|
||||||
val videoUri = videosUrlArray[index]
|
val videoUri = videosUrlArray[index]
|
||||||
val audioUrl = getMostBitRate(streams.audioStreams!!)
|
val audioUrl = PlayerHelper.getMostBitRate(streams.audioStreams!!)
|
||||||
setMediaSource(videoUri, audioUrl)
|
setMediaSource(videoUri, audioUrl)
|
||||||
playerBinding.qualityText.text = videosNameArray[index]
|
playerBinding.qualityText.text = videosNameArray[index]
|
||||||
return
|
return
|
||||||
@ -1255,7 +1253,7 @@ class PlayerFragment : Fragment() {
|
|||||||
// if nothing found, use the first list entry
|
// if nothing found, use the first list entry
|
||||||
if (videosUrlArray.isNotEmpty()) {
|
if (videosUrlArray.isNotEmpty()) {
|
||||||
val videoUri = videosUrlArray[0]
|
val videoUri = videosUrlArray[0]
|
||||||
val audioUrl = getMostBitRate(streams.audioStreams!!)
|
val audioUrl = PlayerHelper.getMostBitRate(streams.audioStreams!!)
|
||||||
setMediaSource(videoUri, audioUrl)
|
setMediaSource(videoUri, audioUrl)
|
||||||
playerBinding.qualityText.text = videosNameArray[0]
|
playerBinding.qualityText.text = videosNameArray[0]
|
||||||
}
|
}
|
||||||
@ -1441,19 +1439,6 @@ class PlayerFragment : Fragment() {
|
|||||||
activity?.runOnUiThread(action)
|
activity?.runOnUiThread(action)
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getMostBitRate(audios: List<PipedStream>): String {
|
|
||||||
var bitrate = 0
|
|
||||||
var index = 0
|
|
||||||
for ((i, audio) in audios.withIndex()) {
|
|
||||||
val q = audio.quality!!.replace(" kbps", "").toInt()
|
|
||||||
if (q > bitrate) {
|
|
||||||
bitrate = q
|
|
||||||
index = i
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return audios[index].url!!
|
|
||||||
}
|
|
||||||
|
|
||||||
private fun fetchComments() {
|
private fun fetchComments() {
|
||||||
lifecycleScope.launchWhenCreated {
|
lifecycleScope.launchWhenCreated {
|
||||||
val commentsResponse = try {
|
val commentsResponse = try {
|
||||||
@ -1542,14 +1527,4 @@ class PlayerFragment : Fragment() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private fun getCaptionStyle(): CaptionStyleCompat {
|
|
||||||
val captioningManager = ContextCompat.getSystemService(
|
|
||||||
requireContext(),
|
|
||||||
CaptioningManager::class.java
|
|
||||||
)
|
|
||||||
return if (captioningManager == null || !captioningManager.isEnabled) {
|
|
||||||
CaptionStyleCompat.DEFAULT
|
|
||||||
} else CaptionStyleCompat.createFromCaptionStyle(captioningManager.userStyle)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
34
app/src/main/java/com/github/libretube/util/PlayerHelper.kt
Normal file
34
app/src/main/java/com/github/libretube/util/PlayerHelper.kt
Normal file
@ -0,0 +1,34 @@
|
|||||||
|
package com.github.libretube.util
|
||||||
|
|
||||||
|
import android.content.Context
|
||||||
|
import android.view.accessibility.CaptioningManager
|
||||||
|
import com.github.libretube.obj.PipedStream
|
||||||
|
import com.google.android.exoplayer2.ui.CaptionStyleCompat
|
||||||
|
|
||||||
|
object PlayerHelper {
|
||||||
|
// get the best bit rate from audio streams
|
||||||
|
fun getMostBitRate(audios: List<PipedStream>): String {
|
||||||
|
var bitrate = 0
|
||||||
|
var index = 0
|
||||||
|
for ((i, audio) in audios.withIndex()) {
|
||||||
|
val q = audio.quality!!.replace(" kbps", "").toInt()
|
||||||
|
if (q > bitrate) {
|
||||||
|
bitrate = q
|
||||||
|
index = i
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return audios[index].url!!
|
||||||
|
}
|
||||||
|
|
||||||
|
// get the system default caption style
|
||||||
|
fun getCaptionStyle(context: Context): CaptionStyleCompat {
|
||||||
|
val captioningManager = context.getSystemService(Context.CAPTIONING_SERVICE) as CaptioningManager
|
||||||
|
return if (!captioningManager.isEnabled) {
|
||||||
|
// system captions are disabled, using android default captions style
|
||||||
|
CaptionStyleCompat.DEFAULT
|
||||||
|
} else {
|
||||||
|
// system captions are enabled
|
||||||
|
CaptionStyleCompat.createFromCaptionStyle(captioningManager.userStyle)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user