|
@@ -24,6 +24,10 @@ import android.view.animation.Animation
|
|
|
import android.view.animation.AnimationUtils
|
|
|
import android.widget.Toast
|
|
|
import androidx.activity.viewModels
|
|
|
+import androidx.compose.animation.AnimatedVisibility
|
|
|
+import androidx.compose.animation.core.tween
|
|
|
+import androidx.compose.animation.slideInVertically
|
|
|
+import androidx.compose.animation.slideOutVertically
|
|
|
import androidx.compose.foundation.layout.Arrangement
|
|
|
import androidx.compose.foundation.layout.Column
|
|
|
import androidx.compose.foundation.layout.Row
|
|
@@ -249,7 +253,7 @@ class ReaderActivity : BaseActivity() {
|
|
|
override fun onResume() {
|
|
|
super.onResume()
|
|
|
viewModel.restartReadTimer()
|
|
|
- setMenuVisibility(viewModel.state.value.menuVisible, animate = false)
|
|
|
+ setMenuVisibility(viewModel.state.value.menuVisible)
|
|
|
}
|
|
|
|
|
|
/**
|
|
@@ -259,7 +263,7 @@ class ReaderActivity : BaseActivity() {
|
|
|
override fun onWindowFocusChanged(hasFocus: Boolean) {
|
|
|
super.onWindowFocusChanged(hasFocus)
|
|
|
if (hasFocus) {
|
|
|
- setMenuVisibility(viewModel.state.value.menuVisible, animate = false)
|
|
|
+ setMenuVisibility(viewModel.state.value.menuVisible)
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -473,43 +477,55 @@ class ReaderActivity : BaseActivity() {
|
|
|
val isPagerType = ReadingModeType.isPagerType(viewModel.getMangaReadingMode())
|
|
|
val cropEnabled = if (isPagerType) cropBorderPaged else cropBorderWebtoon
|
|
|
|
|
|
- Column(
|
|
|
- verticalArrangement = Arrangement.spacedBy(8.dp),
|
|
|
+ AnimatedVisibility(
|
|
|
+ visible = state.menuVisible,
|
|
|
+ enter = slideInVertically(
|
|
|
+ initialOffsetY = { it },
|
|
|
+ animationSpec = tween(200),
|
|
|
+ ),
|
|
|
+ exit = slideOutVertically(
|
|
|
+ targetOffsetY = { it },
|
|
|
+ animationSpec = tween(200),
|
|
|
+ ),
|
|
|
) {
|
|
|
- ChapterNavigator(
|
|
|
- isRtl = isRtl,
|
|
|
- onNextChapter = ::loadNextChapter,
|
|
|
- enabledNext = state.viewerChapters?.nextChapter != null,
|
|
|
- onPreviousChapter = ::loadPreviousChapter,
|
|
|
- enabledPrevious = state.viewerChapters?.prevChapter != null,
|
|
|
- currentPage = state.currentPage,
|
|
|
- totalPages = state.totalPages,
|
|
|
- onSliderValueChange = {
|
|
|
- isScrollingThroughPages = true
|
|
|
- moveToPageIndex(it)
|
|
|
- },
|
|
|
- )
|
|
|
+ Column(
|
|
|
+ verticalArrangement = Arrangement.spacedBy(8.dp),
|
|
|
+ ) {
|
|
|
+ ChapterNavigator(
|
|
|
+ isRtl = isRtl,
|
|
|
+ onNextChapter = ::loadNextChapter,
|
|
|
+ enabledNext = state.viewerChapters?.nextChapter != null,
|
|
|
+ onPreviousChapter = ::loadPreviousChapter,
|
|
|
+ enabledPrevious = state.viewerChapters?.prevChapter != null,
|
|
|
+ currentPage = state.currentPage,
|
|
|
+ totalPages = state.totalPages,
|
|
|
+ onSliderValueChange = {
|
|
|
+ isScrollingThroughPages = true
|
|
|
+ moveToPageIndex(it)
|
|
|
+ },
|
|
|
+ )
|
|
|
|
|
|
- BottomReaderBar(
|
|
|
- readingMode = ReadingModeType.fromPreference(viewModel.getMangaReadingMode(resolveDefault = false)),
|
|
|
- onClickReadingMode = viewModel::openReadingModeSelectDialog,
|
|
|
- orientationMode = OrientationType.fromPreference(viewModel.getMangaOrientationType(resolveDefault = false)),
|
|
|
- onClickOrientationMode = viewModel::openOrientationModeSelectDialog,
|
|
|
- cropEnabled = cropEnabled,
|
|
|
- onClickCropBorder = {
|
|
|
- val enabled = viewModel.toggleCropBorders()
|
|
|
-
|
|
|
- menuToggleToast?.cancel()
|
|
|
- menuToggleToast = toast(
|
|
|
- if (enabled) {
|
|
|
- R.string.on
|
|
|
- } else {
|
|
|
- R.string.off
|
|
|
- },
|
|
|
- )
|
|
|
- },
|
|
|
- onClickSettings = viewModel::openSettingsDialog,
|
|
|
- )
|
|
|
+ BottomReaderBar(
|
|
|
+ readingMode = ReadingModeType.fromPreference(viewModel.getMangaReadingMode(resolveDefault = false)),
|
|
|
+ onClickReadingMode = viewModel::openReadingModeSelectDialog,
|
|
|
+ orientationMode = OrientationType.fromPreference(viewModel.getMangaOrientationType(resolveDefault = false)),
|
|
|
+ onClickOrientationMode = viewModel::openOrientationModeSelectDialog,
|
|
|
+ cropEnabled = cropEnabled,
|
|
|
+ onClickCropBorder = {
|
|
|
+ val enabled = viewModel.toggleCropBorders()
|
|
|
+
|
|
|
+ menuToggleToast?.cancel()
|
|
|
+ menuToggleToast = toast(
|
|
|
+ if (enabled) {
|
|
|
+ R.string.on
|
|
|
+ } else {
|
|
|
+ R.string.off
|
|
|
+ },
|
|
|
+ )
|
|
|
+ },
|
|
|
+ onClickSettings = viewModel::openSettingsDialog,
|
|
|
+ )
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -531,54 +547,41 @@ class ReaderActivity : BaseActivity() {
|
|
|
}
|
|
|
|
|
|
/**
|
|
|
- * Sets the visibility of the menu according to [visible] and with an optional parameter to
|
|
|
- * [animate] the views.
|
|
|
+ * Sets the visibility of the menu according to [visible].
|
|
|
*/
|
|
|
- private fun setMenuVisibility(visible: Boolean, animate: Boolean = true) {
|
|
|
+ private fun setMenuVisibility(visible: Boolean) {
|
|
|
viewModel.showMenus(visible)
|
|
|
if (visible) {
|
|
|
windowInsetsController.show(WindowInsetsCompat.Type.systemBars())
|
|
|
binding.readerMenu.isVisible = true
|
|
|
|
|
|
- if (animate) {
|
|
|
- val toolbarAnimation = AnimationUtils.loadAnimation(this, R.anim.enter_from_top)
|
|
|
- toolbarAnimation.applySystemAnimatorScale(this)
|
|
|
- toolbarAnimation.setAnimationListener(
|
|
|
- object : SimpleAnimationListener() {
|
|
|
- override fun onAnimationStart(animation: Animation) {
|
|
|
- // Fix status bar being translucent the first time it's opened.
|
|
|
- window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS)
|
|
|
- }
|
|
|
- },
|
|
|
- )
|
|
|
- binding.toolbar.startAnimation(toolbarAnimation)
|
|
|
-
|
|
|
- val bottomAnimation = AnimationUtils.loadAnimation(this, R.anim.enter_from_bottom)
|
|
|
- bottomAnimation.applySystemAnimatorScale(this)
|
|
|
- binding.readerMenuBottom.startAnimation(bottomAnimation)
|
|
|
- }
|
|
|
+ val toolbarAnimation = AnimationUtils.loadAnimation(this, R.anim.enter_from_top)
|
|
|
+ toolbarAnimation.applySystemAnimatorScale(this)
|
|
|
+ toolbarAnimation.setAnimationListener(
|
|
|
+ object : SimpleAnimationListener() {
|
|
|
+ override fun onAnimationStart(animation: Animation) {
|
|
|
+ // Fix status bar being translucent the first time it's opened.
|
|
|
+ window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS)
|
|
|
+ }
|
|
|
+ },
|
|
|
+ )
|
|
|
+ binding.toolbar.startAnimation(toolbarAnimation)
|
|
|
} else {
|
|
|
if (readerPreferences.fullscreen().get()) {
|
|
|
windowInsetsController.hide(WindowInsetsCompat.Type.systemBars())
|
|
|
windowInsetsController.systemBarsBehavior = WindowInsetsControllerCompat.BEHAVIOR_SHOW_TRANSIENT_BARS_BY_SWIPE
|
|
|
}
|
|
|
|
|
|
- if (animate) {
|
|
|
- val toolbarAnimation = AnimationUtils.loadAnimation(this, R.anim.exit_to_top)
|
|
|
- toolbarAnimation.applySystemAnimatorScale(this)
|
|
|
- toolbarAnimation.setAnimationListener(
|
|
|
- object : SimpleAnimationListener() {
|
|
|
- override fun onAnimationEnd(animation: Animation) {
|
|
|
- binding.readerMenu.isVisible = false
|
|
|
- }
|
|
|
- },
|
|
|
- )
|
|
|
- binding.toolbar.startAnimation(toolbarAnimation)
|
|
|
-
|
|
|
- val bottomAnimation = AnimationUtils.loadAnimation(this, R.anim.exit_to_bottom)
|
|
|
- bottomAnimation.applySystemAnimatorScale(this)
|
|
|
- binding.readerMenuBottom.startAnimation(bottomAnimation)
|
|
|
- }
|
|
|
+ val toolbarAnimation = AnimationUtils.loadAnimation(this, R.anim.exit_to_top)
|
|
|
+ toolbarAnimation.applySystemAnimatorScale(this)
|
|
|
+ toolbarAnimation.setAnimationListener(
|
|
|
+ object : SimpleAnimationListener() {
|
|
|
+ override fun onAnimationEnd(animation: Animation) {
|
|
|
+ binding.readerMenu.isVisible = false
|
|
|
+ }
|
|
|
+ },
|
|
|
+ )
|
|
|
+ binding.toolbar.startAnimation(toolbarAnimation)
|
|
|
}
|
|
|
}
|
|
|
|