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

Commit 04b33a93 authored by Evan Laird's avatar Evan Laird Committed by android-build-merger
Browse files

Merge "Use a Region when calculating TouchableRegion for cutouts" into qt-dev

am: 6c22dff6

Change-Id: Ia502033c71a1593c7c6aa451f71a208245d0ff96
parents 3e0f8cc0 6c22dff6
Loading
Loading
Loading
Loading
+7 −3
Original line number Diff line number Diff line
@@ -22,6 +22,7 @@ import android.content.Context;
import android.content.res.Configuration;
import android.content.res.Resources;
import android.graphics.Rect;
import android.graphics.Region;
import android.util.Log;
import android.util.Pools;
import android.view.DisplayCutout;
@@ -76,7 +77,7 @@ public class HeadsUpManagerPhone extends HeadsUpManager implements Dumpable,
    private int[] mTmpTwoArray = new int[2];
    private boolean mHeadsUpGoingAway;
    private int mStatusBarState;
    private Rect mTouchableRegion = new Rect();
    private Region mTouchableRegion = new Region();

    private AnimationStateHandler mAnimationStateHandler;

@@ -299,10 +300,11 @@ public class HeadsUpManagerPhone extends HeadsUpManager implements Dumpable,
        info.touchableRegion.set(calculateTouchableRegion());
    }

    public Rect calculateTouchableRegion() {
    public Region calculateTouchableRegion() {
        if (!hasPinnedHeadsUp()) {
            mTouchableRegion.set(0, 0, mStatusBarWindowView.getWidth(), mStatusBarHeight);
            updateRegionForNotch(mTouchableRegion);

        } else {
            NotificationEntry topEntry = getTopEntry();
            if (topEntry.isChildInGroup()) {
@@ -322,7 +324,7 @@ public class HeadsUpManagerPhone extends HeadsUpManager implements Dumpable,
        return mTouchableRegion;
    }

    private void updateRegionForNotch(Rect region) {
    private void updateRegionForNotch(Region region) {
        DisplayCutout cutout = mStatusBarWindowView.getRootWindowInsets().getDisplayCutout();
        if (cutout == null) {
            return;
@@ -390,6 +392,8 @@ public class HeadsUpManagerPhone extends HeadsUpManager implements Dumpable,
        super.dumpInternal(fd, pw, args);
        pw.print("  mBarState=");
        pw.println(mStatusBarState);
        pw.print("  mTouchableRegion=");
        pw.println(mTouchableRegion);
    }

    ///////////////////////////////////////////////////////////////////////////////////////////////
+4 −2
Original line number Diff line number Diff line
@@ -38,6 +38,7 @@ import android.graphics.PointF;
import android.graphics.PorterDuff;
import android.graphics.PorterDuffXfermode;
import android.graphics.Rect;
import android.graphics.Region;
import android.os.PowerManager;
import android.util.AttributeSet;
import android.util.Log;
@@ -620,9 +621,10 @@ public class NotificationPanelView extends PanelView implements

    private Rect calculateGestureExclusionRect() {
        Rect exclusionRect = null;
        if (isFullyCollapsed()) {
        Region touchableRegion = mHeadsUpManager.calculateTouchableRegion();
        if (isFullyCollapsed() && touchableRegion != null) {
            // Note: The heads up manager also calculates the non-pinned touchable region
            exclusionRect = mHeadsUpManager.calculateTouchableRegion();
            exclusionRect = touchableRegion.getBounds();
        }
        return exclusionRect != null
                ? exclusionRect