mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-03-01 00:06:47 +00:00
Calculate StatusBar height locally in Launcher
When reading the status bar inset on devices with multiple displays after switching the displays the inset is not updated immediately (SystemUI should update the height of the window first by reacting to the display switch in it's own process). Due to this race condition Launcher is very likely to calculate DeviceProfile with incorrect inset of the previous display first and update it to the correct one only after SystemUI finished the window update. To avoid this adding calculation of the StatusBar height to Launcher locally using the same utility method that is used by SystemUI. Bug: 264656380 Test: manual test that the statusbar height is calculated correctly in Launcher on a device with two displays, both on the inner and outer display and different rotations Change-Id: Ia16ecadd8fcac29082d27ca693ab7740ce6161c4
This commit is contained in:
@@ -161,12 +161,10 @@ public class WindowManagerProxy implements ResourceBasedOverride {
|
||||
insetsBuilder.setInsetsIgnoringVisibility(WindowInsets.Type.navigationBars(), newNavInsets);
|
||||
|
||||
Insets statusBarInsets = oldInsets.getInsets(WindowInsets.Type.statusBars());
|
||||
int statusBarHeight = getDimenByName(systemRes,
|
||||
(isPortrait) ? STATUS_BAR_HEIGHT_PORTRAIT : STATUS_BAR_HEIGHT_LANDSCAPE,
|
||||
STATUS_BAR_HEIGHT);
|
||||
|
||||
Insets newStatusBarInsets = Insets.of(
|
||||
statusBarInsets.left,
|
||||
Math.max(statusBarInsets.top, statusBarHeight),
|
||||
getStatusBarHeight(context, isPortrait, statusBarInsets.top),
|
||||
statusBarInsets.right,
|
||||
statusBarInsets.bottom);
|
||||
insetsBuilder.setInsets(WindowInsets.Type.statusBars(), newStatusBarInsets);
|
||||
@@ -190,6 +188,15 @@ public class WindowManagerProxy implements ResourceBasedOverride {
|
||||
return result;
|
||||
}
|
||||
|
||||
protected int getStatusBarHeight(Context context, boolean isPortrait, int statusBarInset) {
|
||||
Resources systemRes = context.getResources();
|
||||
int statusBarHeight = getDimenByName(systemRes,
|
||||
isPortrait ? STATUS_BAR_HEIGHT_PORTRAIT : STATUS_BAR_HEIGHT_LANDSCAPE,
|
||||
STATUS_BAR_HEIGHT);
|
||||
|
||||
return Math.max(statusBarInset, statusBarHeight);
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns a list of possible WindowBounds for the display keyed on the 4 surface rotations
|
||||
*/
|
||||
@@ -212,6 +219,9 @@ public class WindowManagerProxy implements ResourceBasedOverride {
|
||||
boolean isTabletOrGesture = isTablet
|
||||
|| (Utilities.ATLEAST_R && isGestureNav(context));
|
||||
|
||||
// Use the status bar height resources because current system API to get the status bar
|
||||
// height doesn't allow to do this for an arbitrary display, it returns value only
|
||||
// for the current active display (see com.android.internal.policy.StatusBarUtils)
|
||||
int statusBarHeightPortrait = getDimenByName(systemRes,
|
||||
STATUS_BAR_HEIGHT_PORTRAIT, STATUS_BAR_HEIGHT);
|
||||
int statusBarHeightLandscape = getDimenByName(systemRes,
|
||||
|
||||
Reference in New Issue
Block a user