crash fixes and android 12 fix

This commit is contained in:
LagradOst 2021-10-13 21:16:46 +02:00
parent ee09f604b8
commit 695c75af10
4 changed files with 62 additions and 53 deletions

View file

@ -23,16 +23,19 @@
android:name="com.google.android.gms.cast.framework.OPTIONS_PROVIDER_CLASS_NAME" android:name="com.google.android.gms.cast.framework.OPTIONS_PROVIDER_CLASS_NAME"
android:value="com.lagradost.cloudstream3.utils.CastOptionsProvider"/> android:value="com.lagradost.cloudstream3.utils.CastOptionsProvider"/>
<activity <activity
android:exported="true"
android:name=".MainActivity" android:name=".MainActivity"
android:configChanges="orientation|screenSize|smallestScreenSize|screenLayout|keyboard|keyboardHidden|navigation" android:configChanges="orientation|screenSize|smallestScreenSize|screenLayout|keyboard|keyboardHidden|navigation"
android:label="@string/app_name" android:label="@string/app_name"
android:resizeableActivity="true" android:resizeableActivity="true"
android:supportsPictureInPicture="true"> android:supportsPictureInPicture="true">
<intent-filter> <intent-filter
android:exported="true">
<action android:name="android.intent.action.MAIN"/> <action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/> <category android:name="android.intent.category.LAUNCHER"/>
</intent-filter> </intent-filter>
<intent-filter> <intent-filter
android:exported="true">
<action android:name="android.intent.action.VIEW"/> <action android:name="android.intent.action.VIEW"/>
<category android:name="android.intent.category.BROWSABLE"/> <category android:name="android.intent.category.BROWSABLE"/>
@ -59,7 +62,7 @@
android:name=".receivers.VideoDownloadRestartReceiver" android:name=".receivers.VideoDownloadRestartReceiver"
android:enabled="false" android:enabled="false"
android:exported="true"> android:exported="true">
<intent-filter> <intent-filter android:exported="true">
<action android:name="restart_service" /> <action android:name="restart_service" />
</intent-filter> </intent-filter>
</receiver> </receiver>
@ -69,7 +72,9 @@
android:exported="false"> android:exported="false">
</service> </service>
<activity android:name=".ui.ControllerActivity"> <activity
android:exported="false"
android:name=".ui.ControllerActivity">
</activity> </activity>
<provider <provider

View file

@ -824,22 +824,22 @@ class PlayerFragment : Fragment() {
exo_play.isClickable = isClick exo_play.isClickable = isClick
exo_pause.isClickable = isClick exo_pause.isClickable = isClick
exo_ffwd.isClickable = isClick exo_ffwd?.isClickable = isClick
exo_rew.isClickable = isClick exo_rew?.isClickable = isClick
exo_prev.isClickable = isClick exo_prev.isClickable = isClick
video_go_back.isClickable = isClick video_go_back.isClickable = isClick
exo_progress.isClickable = isClick exo_progress.isClickable = isClick
//next_episode_btt.isClickable = isClick //next_episode_btt.isClickable = isClick
playback_speed_btt.isClickable = isClick playback_speed_btt?.isClickable = isClick
skip_op?.isClickable = isClick skip_op?.isClickable = isClick
skip_episode?.isClickable = isClick skip_episode?.isClickable = isClick
resize_player.isClickable = isClick resize_player?.isClickable = isClick
exo_progress.isEnabled = isClick exo_progress.isEnabled = isClick
player_media_route_button.isEnabled = isClick player_media_route_button?.isEnabled = isClick
if (isClick) { if (isClick) {
player_pause_holder.alpha = 1f player_pause_holder?.alpha = 1f
player_rew_holder.alpha = 1f player_rew_holder?.alpha = 1f
player_ffwd_holder.alpha = 1f player_ffwd_holder?.alpha = 1f
} }
//video_go_back_holder2.isEnabled = isClick //video_go_back_holder2.isEnabled = isClick
@ -1001,7 +1001,7 @@ class PlayerFragment : Fragment() {
setPreferredSubLanguage(ctx.getAutoSelectLanguageISO639_1()) setPreferredSubLanguage(ctx.getAutoSelectLanguageISO639_1())
} }
subView = player_view.findViewById(R.id.exo_subtitles) subView = player_view?.findViewById(R.id.exo_subtitles)
subView?.let { sView -> subView?.let { sView ->
(sView.parent as ViewGroup?)?.removeView(sView) (sView.parent as ViewGroup?)?.removeView(sView)
subtitle_holder.addView(sView) subtitle_holder.addView(sView)
@ -1041,11 +1041,11 @@ class PlayerFragment : Fragment() {
CastButtonFactory.setUpMediaRouteButton(act, player_media_route_button) CastButtonFactory.setUpMediaRouteButton(act, player_media_route_button)
val castContext = CastContext.getSharedInstance(requireContext()) val castContext = CastContext.getSharedInstance(requireContext())
if (castContext.castState != CastState.NO_DEVICES_AVAILABLE) player_media_route_button.visibility = if (castContext.castState != CastState.NO_DEVICES_AVAILABLE) player_media_route_button?.visibility =
VISIBLE VISIBLE
castContext.addCastStateListener { state -> castContext.addCastStateListener { state ->
if (player_media_route_button != null) { if (player_media_route_button != null) {
player_media_route_button.isVisible = state != CastState.NO_DEVICES_AVAILABLE player_media_route_button?.isVisible = state != CastState.NO_DEVICES_AVAILABLE
if (state == CastState.CONNECTED) { if (state == CastState.CONNECTED) {
if (!this::exoPlayer.isInitialized) return@addCastStateListener if (!this::exoPlayer.isInitialized) return@addCastStateListener
@ -1138,7 +1138,7 @@ class PlayerFragment : Fragment() {
GONE else VISIBLE GONE else VISIBLE
else VISIBLE else VISIBLE
player_media_route_button.isVisible = !isDownloadedFile player_media_route_button?.isVisible = !isDownloadedFile
if (savedInstanceState != null) { if (savedInstanceState != null) {
currentWindow = savedInstanceState.getInt(STATE_RESUME_WINDOW) currentWindow = savedInstanceState.getInt(STATE_RESUME_WINDOW)
playbackPosition = savedInstanceState.getLong(STATE_RESUME_POSITION) playbackPosition = savedInstanceState.getLong(STATE_RESUME_POSITION)
@ -1217,13 +1217,13 @@ class PlayerFragment : Fragment() {
} }
} }
val fastForwardTime = settingsManager.getInt(getString(R.string.fast_forward_button_time_key), 10) val fastForwardTime = settingsManager.getInt(getString(R.string.fast_forward_button_time_key), 10)
exo_rew_text.text = getString(R.string.rew_text_regular_format).format(fastForwardTime) exo_rew_text?.text = getString(R.string.rew_text_regular_format).format(fastForwardTime)
exo_ffwd_text.text = getString(R.string.ffw_text_regular_format).format(fastForwardTime) exo_ffwd_text?.text = getString(R.string.ffw_text_regular_format).format(fastForwardTime)
fun rewind() { fun rewind() {
player_rew_holder.alpha = 1f player_rew_holder?.alpha = 1f
val rotateLeft = AnimationUtils.loadAnimation(context, R.anim.rotate_left) val rotateLeft = AnimationUtils.loadAnimation(context, R.anim.rotate_left)
exo_rew.startAnimation(rotateLeft) exo_rew?.startAnimation(rotateLeft)
val goLeft = AnimationUtils.loadAnimation(context, R.anim.go_left) val goLeft = AnimationUtils.loadAnimation(context, R.anim.go_left)
goLeft.setAnimationListener(object : Animation.AnimationListener { goLeft.setAnimationListener(object : Animation.AnimationListener {
@ -1232,25 +1232,25 @@ class PlayerFragment : Fragment() {
override fun onAnimationRepeat(animation: Animation?) {} override fun onAnimationRepeat(animation: Animation?) {}
override fun onAnimationEnd(animation: Animation?) { override fun onAnimationEnd(animation: Animation?) {
exo_rew_text.post { exo_rew_text?.post {
exo_rew_text.text = getString(R.string.rew_text_regular_format).format(fastForwardTime) exo_rew_text?.text = getString(R.string.rew_text_regular_format).format(fastForwardTime)
player_rew_holder.alpha = if (isShowing) 1f else 0f player_rew_holder?.alpha = if (isShowing) 1f else 0f
} }
} }
}) })
exo_rew_text.startAnimation(goLeft) exo_rew_text?.startAnimation(goLeft)
exo_rew_text.text = getString(R.string.rew_text_format).format(fastForwardTime) exo_rew_text?.text = getString(R.string.rew_text_format).format(fastForwardTime)
seekTime(fastForwardTime * -1000L) seekTime(fastForwardTime * -1000L)
} }
exo_rew.setOnClickListener { exo_rew?.setOnClickListener {
rewind() rewind()
} }
fun fastForward() { fun fastForward() {
player_ffwd_holder.alpha = 1f player_ffwd_holder?.alpha = 1f
val rotateRight = AnimationUtils.loadAnimation(context, R.anim.rotate_right) val rotateRight = AnimationUtils.loadAnimation(context, R.anim.rotate_right)
exo_ffwd.startAnimation(rotateRight) exo_ffwd?.startAnimation(rotateRight)
val goRight = AnimationUtils.loadAnimation(context, R.anim.go_right) val goRight = AnimationUtils.loadAnimation(context, R.anim.go_right)
goRight.setAnimationListener(object : Animation.AnimationListener { goRight.setAnimationListener(object : Animation.AnimationListener {
@ -1259,18 +1259,18 @@ class PlayerFragment : Fragment() {
override fun onAnimationRepeat(animation: Animation?) {} override fun onAnimationRepeat(animation: Animation?) {}
override fun onAnimationEnd(animation: Animation?) { override fun onAnimationEnd(animation: Animation?) {
exo_ffwd_text.post { exo_ffwd_text?.post {
exo_ffwd_text.text = getString(R.string.ffw_text_regular_format).format(fastForwardTime) exo_ffwd_text?.text = getString(R.string.ffw_text_regular_format).format(fastForwardTime)
player_ffwd_holder.alpha = if (isShowing) 1f else 0f player_ffwd_holder?.alpha = if (isShowing) 1f else 0f
} }
} }
}) })
exo_ffwd_text.startAnimation(goRight) exo_ffwd_text?.startAnimation(goRight)
exo_ffwd_text.text = getString(R.string.ffw_text_format).format(fastForwardTime) exo_ffwd_text?.text = getString(R.string.ffw_text_format).format(fastForwardTime)
seekTime(fastForwardTime * 1000L) seekTime(fastForwardTime * 1000L)
} }
exo_ffwd.setOnClickListener { exo_ffwd?.setOnClickListener {
fastForward() fastForward()
} }
@ -1284,7 +1284,7 @@ class PlayerFragment : Fragment() {
} }
} }
lock_player.setOnClickListener { lock_player?.setOnClickListener {
isLocked = !isLocked isLocked = !isLocked
val fadeTo = if (isLocked) 0f else 1f val fadeTo = if (isLocked) 0f else 1f
@ -1295,10 +1295,10 @@ class PlayerFragment : Fragment() {
// MENUS // MENUS
//centerMenu.startAnimation(fadeAnimation) //centerMenu.startAnimation(fadeAnimation)
player_pause_holder.startAnimation(fadeAnimation) player_pause_holder?.startAnimation(fadeAnimation)
player_ffwd_holder.startAnimation(fadeAnimation) player_ffwd_holder?.startAnimation(fadeAnimation)
player_rew_holder.startAnimation(fadeAnimation) player_rew_holder?.startAnimation(fadeAnimation)
player_media_route_button.startAnimation(fadeAnimation) player_media_route_button?.startAnimation(fadeAnimation)
//video_bar.startAnimation(fadeAnimation) //video_bar.startAnimation(fadeAnimation)
//TITLE //TITLE
@ -1355,8 +1355,8 @@ class PlayerFragment : Fragment() {
activity?.popCurrentPage() activity?.popCurrentPage()
} }
playback_speed_btt.isVisible = playBackSpeedEnabled playback_speed_btt?.isVisible = playBackSpeedEnabled
playback_speed_btt.setOnClickListener { playback_speed_btt?.setOnClickListener {
val speedsText = listOf("0.5x", "0.75x", "1x", "1.25x", "1.5x", "1.75x", "2x") val speedsText = listOf("0.5x", "0.75x", "1x", "1.25x", "1.5x", "1.75x", "2x")
val speedsNumbers = listOf(0.5f, 0.75f, 1f, 1.25f, 1.5f, 1.75f, 2f) val speedsNumbers = listOf(0.5f, 0.75f, 1f, 1.25f, 1.5f, 1.75f, 2f)
val speedIndex = speedsNumbers.indexOf(playbackSpeed) val speedIndex = speedsNumbers.indexOf(playbackSpeed)
@ -1368,7 +1368,7 @@ class PlayerFragment : Fragment() {
requireContext().setKey(PLAYBACK_SPEED_KEY, playbackSpeed) requireContext().setKey(PLAYBACK_SPEED_KEY, playbackSpeed)
val param = PlaybackParameters(playbackSpeed) val param = PlaybackParameters(playbackSpeed)
exoPlayer.playbackParameters = param exoPlayer.playbackParameters = param
player_speed_text.text = player_speed_text?.text =
getString(R.string.player_speed_text_format).format(playbackSpeed).replace(".0x", "x") getString(R.string.player_speed_text_format).format(playbackSpeed).replace(".0x", "x")
} }
} }
@ -1471,21 +1471,21 @@ class PlayerFragment : Fragment() {
} }
} }
player_view.resizeMode = resizeModes[resizeMode].first player_view?.resizeMode = resizeModes[resizeMode].first
if (playerResizeEnabled) { if (playerResizeEnabled) {
resize_player.visibility = VISIBLE resize_player?.visibility = VISIBLE
resize_player.setOnClickListener { resize_player?.setOnClickListener {
resizeMode = (resizeMode + 1) % resizeModes.size resizeMode = (resizeMode + 1) % resizeModes.size
requireContext().setKey(RESIZE_MODE_KEY, resizeMode) requireContext().setKey(RESIZE_MODE_KEY, resizeMode)
player_view.resizeMode = resizeModes[resizeMode].first player_view?.resizeMode = resizeModes[resizeMode].first
activity?.let { act -> activity?.let { act ->
showToast(act, resizeModes[resizeMode].second, LENGTH_SHORT) showToast(act, resizeModes[resizeMode].second, LENGTH_SHORT)
} }
//exoPlayer.videoScalingMode = C.VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING //exoPlayer.videoScalingMode = C.VIDEO_SCALING_MODE_SCALE_TO_FIT_WITH_CROPPING
} }
} else { } else {
resize_player.visibility = GONE resize_player?.visibility = GONE
} }
skip_op?.setOnClickListener { skip_op?.setOnClickListener {
@ -1605,7 +1605,7 @@ class PlayerFragment : Fragment() {
if (!isCurrentlyPlaying) { if (!isCurrentlyPlaying) {
initPlayer() initPlayer()
} }
if (player_view != null) player_view.onResume() if (player_view != null) player_view?.onResume()
} }
override fun onResume() { override fun onResume() {
@ -1626,7 +1626,7 @@ class PlayerFragment : Fragment() {
if (!isCurrentlyPlaying) { if (!isCurrentlyPlaying) {
initPlayer() initPlayer()
} }
if (player_view != null) player_view.onResume() if (player_view != null) player_view?.onResume()
} }
} }
@ -1674,7 +1674,7 @@ class PlayerFragment : Fragment() {
super.onPause() super.onPause()
// torrentStream?.currentTorrent?.pause() // torrentStream?.currentTorrent?.pause()
if (Util.SDK_INT <= 23) { if (Util.SDK_INT <= 23) {
if (player_view != null) player_view.onPause() if (player_view != null) player_view?.onPause()
releasePlayer() releasePlayer()
} }
} }
@ -1683,7 +1683,7 @@ class PlayerFragment : Fragment() {
savePos() savePos()
super.onStop() super.onStop()
if (Util.SDK_INT > 23) { if (Util.SDK_INT > 23) {
if (player_view != null) player_view.onPause() if (player_view != null) player_view?.onPause()
releasePlayer() releasePlayer()
} }
} }
@ -1941,7 +1941,7 @@ class PlayerFragment : Fragment() {
} }
} }
player_view.performClick() player_view?.performClick()
//TODO FIX //TODO FIX
video_title?.text = hName + video_title?.text = hName +

View file

@ -322,6 +322,7 @@
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="wrap_content"> android:layout_height="wrap_content">
<com.google.android.material.button.MaterialButton <com.google.android.material.button.MaterialButton
android:layout_marginBottom="5dp"
android:nextFocusUp="@id/result_descript" android:nextFocusUp="@id/result_descript"
android:nextFocusDown="@id/result_download_movie" android:nextFocusDown="@id/result_download_movie"

View file

@ -17,6 +17,7 @@
android:layout_marginBottom="10dp" android:layout_marginBottom="10dp"
> >
<LinearLayout <LinearLayout
android:foreground="?android:attr/selectableItemBackgroundBorderless"
android:padding="10dp" android:padding="10dp"
android:orientation="vertical" android:orientation="vertical"
android:layout_width="match_parent" android:layout_width="match_parent"
@ -29,14 +30,16 @@
<androidx.cardview.widget.CardView <androidx.cardview.widget.CardView
android:layout_width="126dp" android:layout_width="126dp"
android:layout_height="72dp" android:layout_height="72dp"
android:foreground="@drawable/outline_drawable"
> >
<ImageView <ImageView
android:nextFocusLeft="@id/result_episode_download" android:nextFocusLeft="@id/result_episode_download"
android:nextFocusRight="@id/episode_holder" android:nextFocusRight="@id/episode_holder"
android:id="@+id/episode_poster" android:id="@+id/episode_poster"
android:foreground="@drawable/outline_drawable"
tools:src="@drawable/example_poster" tools:src="@drawable/example_poster"
android:foreground="?android:attr/selectableItemBackgroundBorderless"
android:scaleType="centerCrop" android:scaleType="centerCrop"
android:layout_width="match_parent" android:layout_width="match_parent"
android:layout_height="match_parent" android:layout_height="match_parent"