diff --git a/app/src/main/java/com/lagradost/cloudstream3/ui/player/FullScreenPlayer.kt b/app/src/main/java/com/lagradost/cloudstream3/ui/player/FullScreenPlayer.kt
index 819e50baee..6508721adc 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/ui/player/FullScreenPlayer.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/ui/player/FullScreenPlayer.kt
@@ -75,6 +75,7 @@ private const val SUBTITLE_DELAY_BUNDLE_KEY = "subtitle_delay"
// All the UI Logic for the player
open class FullScreenPlayer : AbstractPlayerFragment() {
+ private var isVerticalOrientation: Boolean = false
protected open var lockRotation = true
protected open var isFullScreenPlayer = true
protected open var isTv = false
@@ -111,6 +112,8 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
protected var playerResizeEnabled = false
protected var doubleTapEnabled = false
protected var doubleTapPauseEnabled = true
+ protected var playerRotateEnabled = false
+ protected var autoPlayerRotateEnabled = false
protected var subtitleDelay
set(value) = try {
@@ -286,6 +289,38 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
player.getCurrentPreferredSubtitle() == null
}
+ private fun restoreOrientationWithSensor(activity: Activity){
+ val currentOrientation = activity.resources.configuration.orientation
+ var orientation = 0
+ when (currentOrientation) {
+ Configuration.ORIENTATION_LANDSCAPE ->
+ orientation = ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE
+
+ Configuration.ORIENTATION_SQUARE, Configuration.ORIENTATION_UNDEFINED ->
+ orientation = dynamicOrientation()
+
+ Configuration.ORIENTATION_PORTRAIT ->
+ orientation = ActivityInfo.SCREEN_ORIENTATION_SENSOR_PORTRAIT
+ }
+ activity.requestedOrientation = orientation
+ }
+
+ private fun toggleOrientationWithSensor(activity: Activity){
+ val currentOrientation = activity.resources.configuration.orientation
+ var orientation = 0
+ when (currentOrientation) {
+ Configuration.ORIENTATION_LANDSCAPE ->
+ orientation = ActivityInfo.SCREEN_ORIENTATION_SENSOR_PORTRAIT
+
+ Configuration.ORIENTATION_SQUARE, Configuration.ORIENTATION_UNDEFINED ->
+ orientation = dynamicOrientation()
+
+ Configuration.ORIENTATION_PORTRAIT ->
+ orientation = ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE
+ }
+ activity.requestedOrientation = orientation
+ }
+
open fun lockOrientation(activity: Activity) {
val display =
(activity.getSystemService(Context.WINDOW_SERVICE) as WindowManager).defaultDisplay
@@ -293,24 +328,39 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
val currentOrientation = activity.resources.configuration.orientation
var orientation = 0
when (currentOrientation) {
- Configuration.ORIENTATION_LANDSCAPE -> orientation =
- if (rotation == Surface.ROTATION_0 || rotation == Surface.ROTATION_90) ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE else ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE
-
- Configuration.ORIENTATION_SQUARE, Configuration.ORIENTATION_UNDEFINED, Configuration.ORIENTATION_PORTRAIT -> ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE
- //Configuration.ORIENTATION_PORTRAIT -> orientation =
- // if (rotation == Surface.ROTATION_0 || rotation == Surface.ROTATION_270) ActivityInfo.SCREEN_ORIENTATION_PORTRAIT else ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT
+ Configuration.ORIENTATION_LANDSCAPE ->
+ orientation =
+ if (rotation == Surface.ROTATION_0 || rotation == Surface.ROTATION_90)
+ ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE
+ else
+ ActivityInfo.SCREEN_ORIENTATION_REVERSE_LANDSCAPE
+
+ Configuration.ORIENTATION_SQUARE, Configuration.ORIENTATION_UNDEFINED ->
+ orientation = dynamicOrientation()
+
+ Configuration.ORIENTATION_PORTRAIT ->
+ orientation =
+ if (rotation == Surface.ROTATION_0 || rotation == Surface.ROTATION_270)
+ ActivityInfo.SCREEN_ORIENTATION_PORTRAIT
+ else
+ ActivityInfo.SCREEN_ORIENTATION_REVERSE_PORTRAIT
}
activity.requestedOrientation = orientation
}
- private fun updateOrientation() {
+ private fun updateOrientation(ignoreDynamicOrientation: Boolean = false) {
activity?.apply {
if(lockRotation) {
if(isLocked) {
lockOrientation(this)
}
else {
- requestedOrientation = ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE
+ if(ignoreDynamicOrientation){
+ // restore when lock is disabled
+ restoreOrientationWithSensor(this)
+ } else {
+ this.requestedOrientation = dynamicOrientation()
+ }
}
}
}
@@ -584,7 +634,7 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
}
isLocked = !isLocked
- updateOrientation()
+ updateOrientation(true) // set true to ignore auto rotate to stay in current orientation
if (isLocked && isShowing) {
playerBinding?.playerHolder?.postDelayed({
@@ -1326,6 +1376,14 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
ctx.getString(R.string.playback_speed_enabled_key),
false
)
+ playerRotateEnabled = settingsManager.getBoolean(
+ ctx.getString(R.string.rotate_video_key),
+ false
+ )
+ autoPlayerRotateEnabled = settingsManager.getBoolean(
+ ctx.getString(R.string.auto_rotate_video_key),
+ false
+ )
playerResizeEnabled =
settingsManager.getBoolean(
ctx.getString(R.string.player_resize_enabled_key),
@@ -1362,6 +1420,7 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
playerBinding?.apply {
playerSpeedBtt.isVisible = playBackSpeedEnabled
playerResizeBtt.isVisible = playerResizeEnabled
+ playerRotateBtt.isVisible = playerRotateEnabled
}
} catch (e: Exception) {
logError(e)
@@ -1376,6 +1435,11 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
player.handleEvent(CSPlayerEvent.SkipCurrentChapter)
}
+ playerRotateBtt.setOnClickListener {
+ autoHide()
+ toggleRotate()
+ }
+
// init clicks
playerResizeBtt.setOnClickListener {
autoHide()
@@ -1481,4 +1545,28 @@ open class FullScreenPlayer : AbstractPlayerFragment() {
logError(e)
}
}
+
+ @SuppressLint("SourceLockedOrientationActivity")
+ private fun toggleRotate() {
+ activity?.let {
+ toggleOrientationWithSensor(it)
+ }
+ }
+
+ override fun playerDimensionsLoaded(width: Int, height: Int) {
+ isVerticalOrientation = height > width
+ updateOrientation()
+ }
+
+ private fun dynamicOrientation(): Int {
+ return if (autoPlayerRotateEnabled) {
+ if (isVerticalOrientation) {
+ ActivityInfo.SCREEN_ORIENTATION_SENSOR_PORTRAIT
+ } else {
+ ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE
+ }
+ } else {
+ ActivityInfo.SCREEN_ORIENTATION_SENSOR_LANDSCAPE // default orientation
+ }
+ }
}
\ No newline at end of file
diff --git a/app/src/main/java/com/lagradost/cloudstream3/ui/player/GeneratorPlayer.kt b/app/src/main/java/com/lagradost/cloudstream3/ui/player/GeneratorPlayer.kt
index 43e51e55d4..0a626471fc 100644
--- a/app/src/main/java/com/lagradost/cloudstream3/ui/player/GeneratorPlayer.kt
+++ b/app/src/main/java/com/lagradost/cloudstream3/ui/player/GeneratorPlayer.kt
@@ -1237,6 +1237,7 @@ class GeneratorPlayer : FullScreenPlayer() {
}
override fun playerDimensionsLoaded(width: Int, height: Int) {
+ super.playerDimensionsLoaded(width, height)
setPlayerDimen(width to height)
}
diff --git a/app/src/main/res/drawable/screen_rotation.xml b/app/src/main/res/drawable/screen_rotation.xml
new file mode 100644
index 0000000000..da0ac0fd56
--- /dev/null
+++ b/app/src/main/res/drawable/screen_rotation.xml
@@ -0,0 +1,10 @@
+
+
+
diff --git a/app/src/main/res/layout/player_custom_layout.xml b/app/src/main/res/layout/player_custom_layout.xml
index 38df4c5bb6..0d73246be0 100644
--- a/app/src/main/res/layout/player_custom_layout.xml
+++ b/app/src/main/res/layout/player_custom_layout.xml
@@ -550,10 +550,19 @@
android:orientation="horizontal">
+
+
diff --git a/app/src/main/res/layout/player_custom_layout_tv.xml b/app/src/main/res/layout/player_custom_layout_tv.xml
index 12c61baae6..de9e04ae60 100644
--- a/app/src/main/res/layout/player_custom_layout_tv.xml
+++ b/app/src/main/res/layout/player_custom_layout_tv.xml
@@ -638,6 +638,11 @@
app:icon="@drawable/video_locked" />
+
+
+
+
Logged in as %s
Skip account selection at startup
Use Default Account
+ Rotate
+ rotate_video_key
+ Display a toggle button for screen orientation
+ auto_rotate_video_key
+ Enable automatic switching of screen orientation based on video orientation
+ Auto rotate
diff --git a/app/src/main/res/xml/settings_player.xml b/app/src/main/res/xml/settings_player.xml
index ad33e036b4..eccb78e36d 100644
--- a/app/src/main/res/xml/settings_player.xml
+++ b/app/src/main/res/xml/settings_player.xml
@@ -86,6 +86,18 @@
app:defaultValue="true"
android:summary="@string/enable_skip_op_from_database_des"
app:key="@string/enable_skip_op_from_database" />
+
+