Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f629b618 authored by Selim Cinek's avatar Selim Cinek
Browse files

Fixed an issue where scrolling didn't work anymore after going to landscape

Because of the way linearlayout measures and because we never invalidated
our measure cache, the measuring of the view would be skipped, leading
to issues. We're now forcing the measurement to be invalidated
when changing the measuredState.

Fixes: 159719742
Test: use crosshatch, go to expanded qs, have 2 players. Rotate back and forth. Observe normal scrolling
Change-Id: I32fc904f884b1032d173c4811576cdb5818bad22
parent 2b33bad9
Loading
Loading
Loading
Loading
+1 −1
Original line number Original line Diff line number Diff line
@@ -464,7 +464,7 @@ class MediaCarouselController @Inject constructor(
        val width = desiredHostState?.measurementInput?.width ?: 0
        val width = desiredHostState?.measurementInput?.width ?: 0
        val height = desiredHostState?.measurementInput?.height ?: 0
        val height = desiredHostState?.measurementInput?.height ?: 0
        if (width != carouselMeasureWidth && width != 0 ||
        if (width != carouselMeasureWidth && width != 0 ||
                height != carouselMeasureWidth && height != 0) {
                height != carouselMeasureHeight && height != 0) {
            carouselMeasureWidth = width
            carouselMeasureWidth = width
            carouselMeasureHeight = height
            carouselMeasureHeight = height
            val playerWidthPlusPadding = carouselMeasureWidth +
            val playerWidthPlusPadding = carouselMeasureWidth +
+1 −1
Original line number Original line Diff line number Diff line
@@ -243,7 +243,7 @@ class MediaCarouselScrollHandler(
            }
            }
            val rotation = (1.0f - settingsOffset) * 50
            val rotation = (1.0f - settingsOffset) * 50
            settingsButton.rotation = rotation * -Math.signum(contentTranslation)
            settingsButton.rotation = rotation * -Math.signum(contentTranslation)
            val alpha = MathUtils.map(0.5f, 1.0f, 0.0f, 1.0f, settingsOffset)
            val alpha = MathUtils.saturate(MathUtils.map(0.5f, 1.0f, 0.0f, 1.0f, settingsOffset))
            settingsButton.alpha = alpha
            settingsButton.alpha = alpha
            settingsButton.visibility = if (alpha != 0.0f) View.VISIBLE else View.INVISIBLE
            settingsButton.visibility = if (alpha != 0.0f) View.VISIBLE else View.INVISIBLE
            settingsButton.translationX = newTranslationX
            settingsButton.translationX = newTranslationX
+18 −1
Original line number Original line Diff line number Diff line
@@ -47,12 +47,29 @@ class TransitionLayout @JvmOverloads constructor(
    private var currentState: TransitionViewState = TransitionViewState()
    private var currentState: TransitionViewState = TransitionViewState()
    private var updateScheduled = false
    private var updateScheduled = false


    private var desiredMeasureWidth = 0
    private var desiredMeasureHeight = 0
    /**
    /**
     * The measured state of this view which is the one we will lay ourselves out with. This
     * The measured state of this view which is the one we will lay ourselves out with. This
     * may differ from the currentState if there is an external animation or transition running.
     * may differ from the currentState if there is an external animation or transition running.
     * This state will not be used to measure the widgets, where the current state is preferred.
     * This state will not be used to measure the widgets, where the current state is preferred.
     */
     */
    var measureState: TransitionViewState = TransitionViewState()
    var measureState: TransitionViewState = TransitionViewState()
        set(value) {
            val newWidth = value.width
            val newHeight = value.height
            if (newWidth != desiredMeasureWidth || newHeight != desiredMeasureHeight) {
                desiredMeasureWidth = newWidth
                desiredMeasureHeight = newHeight
                // We need to make sure next time we're measured that our onMeasure will be called.
                // Otherwise our parent thinks we still have the same height
                if (isInLayout()) {
                    forceLayout()
                } else {
                    requestLayout()
                }
            }
        }
    private val preDrawApplicator = object : ViewTreeObserver.OnPreDrawListener {
    private val preDrawApplicator = object : ViewTreeObserver.OnPreDrawListener {
        override fun onPreDraw(): Boolean {
        override fun onPreDraw(): Boolean {
            updateScheduled = false
            updateScheduled = false
@@ -158,7 +175,7 @@ class TransitionLayout @JvmOverloads constructor(
                        MeasureSpec.EXACTLY)
                        MeasureSpec.EXACTLY)
                child.measure(measureWidthSpec, measureHeightSpec)
                child.measure(measureWidthSpec, measureHeightSpec)
            }
            }
            setMeasuredDimension(measureState.width, measureState.height)
            setMeasuredDimension(desiredMeasureWidth, desiredMeasureHeight)
        }
        }
    }
    }