Introduce AMS.getLastResumedActivityUserId to fix work profile icon issue
am: ec319aba34
Change-Id: I41eb1a9f2e3dd97b5318c3dee92c73e4d531966b
This commit is contained in:
@@ -629,6 +629,11 @@ interface IActivityManager {
|
||||
*/
|
||||
void setDisablePreviewScreenshots(IBinder token, boolean disable);
|
||||
|
||||
/**
|
||||
* Return the user id of last resumed activity.
|
||||
*/
|
||||
int getLastResumedActivityUserId();
|
||||
|
||||
// WARNING: when these transactions are updated, check if they are any callers on the native
|
||||
// side. If so, make sure they are using the correct transaction ids and arguments.
|
||||
// If a transaction which will also be used on the native side is being inserted, add it
|
||||
|
||||
@@ -127,7 +127,6 @@ public class PhoneStatusBarPolicy implements Callback, Callbacks,
|
||||
private boolean mVolumeVisible;
|
||||
private boolean mCurrentUserSetup;
|
||||
|
||||
private boolean mManagedProfileFocused = false;
|
||||
private boolean mManagedProfileIconVisible = false;
|
||||
private boolean mManagedProfileInQuietMode = false;
|
||||
|
||||
@@ -439,45 +438,30 @@ public class PhoneStatusBarPolicy implements Callback, Callbacks,
|
||||
}
|
||||
}
|
||||
|
||||
private void profileChanged(int userId) {
|
||||
UserInfo user = null;
|
||||
if (userId == UserHandle.USER_CURRENT) {
|
||||
try {
|
||||
user = ActivityManager.getService().getCurrentUser();
|
||||
} catch (RemoteException e) {
|
||||
// Ignore
|
||||
}
|
||||
} else {
|
||||
user = mUserManager.getUserInfo(userId);
|
||||
}
|
||||
|
||||
mManagedProfileFocused = user != null && user.isManagedProfile();
|
||||
if (DEBUG) Log.v(TAG, "profileChanged: mManagedProfileFocused: " + mManagedProfileFocused);
|
||||
// Actually update the icon later when transition starts.
|
||||
}
|
||||
|
||||
private void updateManagedProfile() {
|
||||
if (DEBUG) {
|
||||
Log.v(TAG, "updateManagedProfile: mManagedProfileFocused: "
|
||||
+ mManagedProfileFocused);
|
||||
}
|
||||
final boolean showIcon;
|
||||
if (mManagedProfileFocused && !mKeyguardMonitor.isShowing()) {
|
||||
showIcon = true;
|
||||
mIconController.setIcon(mSlotManagedProfile,
|
||||
R.drawable.stat_sys_managed_profile_status,
|
||||
mContext.getString(R.string.accessibility_managed_profile));
|
||||
} else if (mManagedProfileInQuietMode) {
|
||||
showIcon = true;
|
||||
mIconController.setIcon(mSlotManagedProfile,
|
||||
R.drawable.stat_sys_managed_profile_status_off,
|
||||
mContext.getString(R.string.accessibility_managed_profile));
|
||||
} else {
|
||||
showIcon = false;
|
||||
}
|
||||
if (mManagedProfileIconVisible != showIcon) {
|
||||
mIconController.setIconVisibility(mSlotManagedProfile, showIcon);
|
||||
mManagedProfileIconVisible = showIcon;
|
||||
try {
|
||||
final boolean showIcon;
|
||||
final int userId = ActivityManager.getService().getLastResumedActivityUserId();
|
||||
if (mUserManager.isManagedProfile(userId) && !mKeyguardMonitor.isShowing()) {
|
||||
showIcon = true;
|
||||
mIconController.setIcon(mSlotManagedProfile,
|
||||
R.drawable.stat_sys_managed_profile_status,
|
||||
mContext.getString(R.string.accessibility_managed_profile));
|
||||
} else if (mManagedProfileInQuietMode) {
|
||||
showIcon = true;
|
||||
mIconController.setIcon(mSlotManagedProfile,
|
||||
R.drawable.stat_sys_managed_profile_status_off,
|
||||
mContext.getString(R.string.accessibility_managed_profile));
|
||||
} else {
|
||||
showIcon = false;
|
||||
}
|
||||
if (mManagedProfileIconVisible != showIcon) {
|
||||
mIconController.setIconVisibility(mSlotManagedProfile, showIcon);
|
||||
mManagedProfileIconVisible = showIcon;
|
||||
}
|
||||
} catch (RemoteException ex) {
|
||||
Log.w(TAG, "updateManagedProfile: ", ex);
|
||||
// ignore
|
||||
}
|
||||
}
|
||||
|
||||
@@ -556,35 +540,16 @@ public class PhoneStatusBarPolicy implements Callback, Callbacks,
|
||||
new SynchronousUserSwitchObserver() {
|
||||
@Override
|
||||
public void onUserSwitching(int newUserId) throws RemoteException {
|
||||
mHandler.post(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
mUserInfoController.reloadUserInfo();
|
||||
}
|
||||
});
|
||||
mHandler.post(() -> mUserInfoController.reloadUserInfo());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onUserSwitchComplete(int newUserId) throws RemoteException {
|
||||
mHandler.post(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
updateAlarm();
|
||||
profileChanged(newUserId);
|
||||
updateQuietState();
|
||||
updateManagedProfile();
|
||||
updateForegroundInstantApps();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onForegroundProfileSwitch(int newProfileId) {
|
||||
mHandler.post(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
profileChanged(newProfileId);
|
||||
}
|
||||
mHandler.post(() -> {
|
||||
updateAlarm();
|
||||
updateQuietState();
|
||||
updateManagedProfile();
|
||||
updateForegroundInstantApps();
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
@@ -3212,18 +3212,18 @@ public class ActivityManagerService extends IActivityManager.Stub
|
||||
}
|
||||
}
|
||||
|
||||
mWindowManager.setFocusedApp(r.appToken, true);
|
||||
|
||||
applyUpdateLockStateLocked(r);
|
||||
applyUpdateVrModeLocked(r);
|
||||
if (mLastResumedActivity != null && r.userId != mLastResumedActivity.userId) {
|
||||
mHandler.removeMessages(FOREGROUND_PROFILE_CHANGED_MSG);
|
||||
mHandler.obtainMessage(
|
||||
FOREGROUND_PROFILE_CHANGED_MSG, r.userId, 0).sendToTarget();
|
||||
}
|
||||
|
||||
mLastResumedActivity = r;
|
||||
|
||||
mWindowManager.setFocusedApp(r.appToken, true);
|
||||
|
||||
applyUpdateLockStateLocked(r);
|
||||
applyUpdateVrModeLocked(r);
|
||||
|
||||
EventLogTags.writeAmSetResumedActivity(
|
||||
r == null ? -1 : r.userId,
|
||||
r == null ? "NULL" : r.shortComponentName,
|
||||
@@ -23599,6 +23599,21 @@ public class ActivityManagerService extends IActivityManager.Stub
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the user id of the last resumed activity.
|
||||
*/
|
||||
@Override
|
||||
public @UserIdInt int getLastResumedActivityUserId() {
|
||||
enforceCallingPermission(
|
||||
permission.INTERACT_ACROSS_USERS_FULL, "getLastResumedActivityUserId()");
|
||||
synchronized (this) {
|
||||
if (mLastResumedActivity == null) {
|
||||
return mUserController.getCurrentUserIdLocked();
|
||||
}
|
||||
return mLastResumedActivity.userId;
|
||||
}
|
||||
}
|
||||
|
||||
private final class SleepTokenImpl extends SleepToken {
|
||||
private final String mTag;
|
||||
private final long mAcquireTime;
|
||||
|
||||
Reference in New Issue
Block a user