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

Commit 7916b69e authored by Ming-Shin Lu's avatar Ming-Shin Lu Committed by Automerger Merge Worker
Browse files

Merge "Calling updateImeParent when the layering target is staled" into sc-dev am: cae02ff4

Original change: https://googleplex-android-review.googlesource.com/c/platform/frameworks/base/+/14842887

Change-Id: Ib138cbd353cfa2e947ba790d873f1384b55a1fc0
parents ccd4e76c cae02ff4
Loading
Loading
Loading
Loading
+9 −4
Original line number Diff line number Diff line
@@ -3842,7 +3842,7 @@ class DisplayContent extends RootDisplayArea implements WindowManagerPolicy.Disp
        // 4. Update the IME control target to apply any inset change and animation.
        // 5. Reparent the IME container surface to either the input target app, or the IME window
        // parent.
        updateImeControlTarget();
        updateImeControlTarget(true /* forceUpdateImeParent */);
    }

    @VisibleForTesting
@@ -3974,12 +3974,17 @@ class DisplayContent extends RootDisplayArea implements WindowManagerPolicy.Disp
    }

    void updateImeControlTarget() {
        updateImeControlTarget(false /* forceUpdateImeParent */);
    }

    void updateImeControlTarget(boolean forceUpdateImeParent) {
        InsetsControlTarget prevImeControlTarget = mImeControlTarget;
        mImeControlTarget = computeImeControlTarget();
        mInsetsStateController.onImeControlTargetChanged(mImeControlTarget);
        // Update Ime parent when IME insets leash created, which is the best time that default
        // IME visibility has been settled down after IME control target changed.
        if (prevImeControlTarget != mImeControlTarget) {
        // Update Ime parent when IME insets leash created or the new IME layering target might
        // updated from setImeLayeringTarget, which is the best time that default IME visibility
        // has been settled down after IME control target changed.
        if (prevImeControlTarget != mImeControlTarget || forceUpdateImeParent) {
            updateImeParent();
        }