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

Commit 334d4341 authored by Christian Göllner's avatar Christian Göllner Committed by Android (Google) Code Review
Browse files

Merge "Fix letterbox overlapping with status bar icons after rotating device" into udc-qpr-dev

parents cf99bb18 6928a934
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -209,7 +209,7 @@ constructor(
        if (this.contains(other) || other.contains(this)) {
            return false
        }
        return this.intersect(other)
        return this.intersects(other.left, other.top, other.right, other.bottom)
    }

    override fun dump(pw: PrintWriter, args: Array<out String>) {
+24 −0
Original line number Diff line number Diff line
@@ -105,6 +105,30 @@ class LetterboxAppearanceCalculatorTest : SysuiTestCase() {
        expect.that(letterboxAppearance.appearanceRegions).isEqualTo(TEST_APPEARANCE_REGIONS)
    }

    /** Regression test for b/287508741 */
    @Test
    fun getLetterboxAppearance_withOverlap_doesNotMutateOriginalBounds() {
        val statusBarStartSideBounds = Rect(left = 0, top = 0, right = 100, bottom = 100)
        val statusBarEndSideBounds = Rect(left = 200, top = 0, right = 300, bottom = 100)
        val letterBoxInnerBounds = Rect(left = 150, top = 50, right = 250, bottom = 150)
        val statusBarStartSideBoundsCopy = Rect(statusBarStartSideBounds)
        val statusBarEndSideBoundsCopy = Rect(statusBarEndSideBounds)
        val letterBoxInnerBoundsCopy = Rect(letterBoxInnerBounds)
        whenever(statusBarBoundsProvider.visibleStartSideBounds)
                .thenReturn(statusBarStartSideBounds)
        whenever(statusBarBoundsProvider.visibleEndSideBounds).thenReturn(statusBarEndSideBounds)

        calculator.getLetterboxAppearance(
                TEST_APPEARANCE,
                TEST_APPEARANCE_REGIONS,
                arrayOf(letterboxWithInnerBounds(letterBoxInnerBounds))
        )

        expect.that(statusBarStartSideBounds).isEqualTo(statusBarStartSideBoundsCopy)
        expect.that(statusBarEndSideBounds).isEqualTo(statusBarEndSideBoundsCopy)
        expect.that(letterBoxInnerBounds).isEqualTo(letterBoxInnerBoundsCopy)
    }

    @Test
    fun getLetterboxAppearance_noOverlap_BackgroundMultiColor_returnsAppearanceWithScrim() {
        whenever(letterboxBackgroundProvider.isLetterboxBackgroundMultiColored).thenReturn(true)