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

Commit 8c8d8b10 authored by Adrian Roos's avatar Adrian Roos Committed by Android (Google) Code Review
Browse files

Merge "Only keep user switcher bitmaps if needed" into lmp-mr1-dev

parents 9c76a7b3 cba0faad
Loading
Loading
Loading
Loading
+7 −0
Original line number Diff line number Diff line
@@ -860,6 +860,10 @@ public class PhoneStatusBar extends BaseStatusBar implements DemoMode,
        mKeyguardUserSwitcher = new KeyguardUserSwitcher(mContext,
                (ViewStub) mStatusBarWindow.findViewById(R.id.keyguard_user_switcher),
                mKeyguardStatusBar, mNotificationPanel, mUserSwitcherController);
        if (mUserSwitcherController != null) {
            mUserSwitcherController.setKeyguardUserSwitcherAvailable(
                    mKeyguardUserSwitcher.isEnabled());
        }


        // Set up the quick settings tile panel
@@ -2126,6 +2130,9 @@ public class PhoneStatusBar extends BaseStatusBar implements DemoMode,

    public void setQsExpanded(boolean expanded) {
        mStatusBarWindowManager.setQsExpanded(expanded);
        if (mUserSwitcherController != null) {
            mUserSwitcherController.setQsExpanded(expanded);
        }
    }

    public boolean isGoingToNotificationShade() {
+4 −0
Original line number Diff line number Diff line
@@ -227,6 +227,10 @@ public class KeyguardUserSwitcher {
        }
    };

    public boolean isEnabled() {
        return mUserSwitcherContainer != null;
    }

    public static class Adapter extends UserSwitcherController.BaseUserAdapter implements
            View.OnClickListener {

+49 −16
Original line number Diff line number Diff line
@@ -78,6 +78,9 @@ public class UserSwitcherController {
    private boolean mSimpleUserSwitcher;
    private boolean mAddUsersWhenLocked;

    private boolean mKeyguardUserSwitcherAvailable;
    private boolean mQsExpanded;

    public UserSwitcherController(Context context, KeyguardMonitor keyguardMonitor) {
        mContext = context;
        mGuestResumeSessionReceiver.register(context);
@@ -116,8 +119,9 @@ public class UserSwitcherController {
     */
    @SuppressWarnings("unchecked")
    private void refreshUsers(int forcePictureLoadForId) {

        SparseArray<Bitmap> bitmaps = new SparseArray<>(mUsers.size());
        SparseArray<Bitmap> bitmaps = null;
        if (allowCachingOfBitmaps()) {
            bitmaps = new SparseArray<>(mUsers.size());
            final int N = mUsers.size();
            for (int i = 0; i < N; i++) {
                UserRecord r = mUsers.get(i);
@@ -127,6 +131,7 @@ public class UserSwitcherController {
                }
                bitmaps.put(r.info.id, r.picture);
            }
        }

        final boolean addUsersWhenLocked = mAddUsersWhenLocked;
        new AsyncTask<SparseArray<Bitmap>, Void, ArrayList<UserRecord>>() {
@@ -151,13 +156,15 @@ public class UserSwitcherController {
                                true /* isGuest */, isCurrent, false /* isAddUser */,
                                false /* isRestricted */);
                    } else if (info.supportsSwitchTo()) {
                        Bitmap picture = bitmaps.get(info.id);
                        if (picture == null) {
                            picture = mUserManager.getUserIcon(info.id);
                        }
                        if (picture != null) {
                        Bitmap picture = bitmaps != null ? bitmaps.get(info.id) : null;
                        if (picture == null && allowCachingOfBitmaps()) {
                            Bitmap loadedPicture = mUserManager.getUserIcon(info.id);

                            if (loadedPicture != null) {
                                picture = BitmapHelper.createCircularClip(
                                    picture, avatarSize, avatarSize);
                                        loadedPicture, avatarSize, avatarSize);
                                loadedPicture.recycle();
                            }
                        }
                        int index = isCurrent ? 0 : records.size();
                        records.add(index, new UserRecord(info, picture, false /* isGuest */,
@@ -552,6 +559,32 @@ public class UserSwitcherController {
        }
    }

    /**
     * Notify if the keyguard user switcher is available.
     */
    public void setKeyguardUserSwitcherAvailable(boolean available) {
        boolean oldShouldCacheBitmaps = allowCachingOfBitmaps();
        mKeyguardUserSwitcherAvailable = available;
        if (allowCachingOfBitmaps() != oldShouldCacheBitmaps) {
            refreshUsers(UserHandle.USER_NULL);
        }
    }

    /**
     * Notify if the quick settings are expanded.
     */
    public void setQsExpanded(boolean qsExpanded) {
        boolean oldShouldCacheBitmaps = allowCachingOfBitmaps();
        mQsExpanded = qsExpanded;
        if (allowCachingOfBitmaps() != oldShouldCacheBitmaps) {
            refreshUsers(UserHandle.USER_NULL);
        }
    }

    private boolean allowCachingOfBitmaps() {
        return mQsExpanded || mKeyguardUserSwitcherAvailable;
    }

    private final class AddUserDialog extends SystemUIDialog implements
            DialogInterface.OnClickListener {