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

Commit 420701ee authored by Winson's avatar Winson Committed by android-build-merger
Browse files

Bump up preloading recents on boot up to user unlocked. am: c3eedd97

am: 3174f293

Change-Id: If01f9e61af46d32601c65949f4931418d170d2a7
parents 6a8fecf7 3174f293
Loading
Loading
Loading
Loading
+24 −2
Original line number Original line Diff line number Diff line
@@ -18,10 +18,12 @@ package com.android.systemui.recents;


import android.app.ActivityManager;
import android.app.ActivityManager;
import android.app.UiModeManager;
import android.app.UiModeManager;
import android.content.BroadcastReceiver;
import android.content.ComponentName;
import android.content.ComponentName;
import android.content.ContentResolver;
import android.content.ContentResolver;
import android.content.Context;
import android.content.Context;
import android.content.Intent;
import android.content.Intent;
import android.content.IntentFilter;
import android.content.ServiceConnection;
import android.content.ServiceConnection;
import android.content.pm.ActivityInfo;
import android.content.pm.ActivityInfo;
import android.content.res.Configuration;
import android.content.res.Configuration;
@@ -96,7 +98,7 @@ public class Recents extends SystemUI
    // and does not reside in the home stack.
    // and does not reside in the home stack.
    private String mOverrideRecentsPackageName;
    private String mOverrideRecentsPackageName;


    private Handler mHandler;
    private Handler mHandler = new Handler();
    private RecentsImpl mImpl;
    private RecentsImpl mImpl;
    private int mDraggingInRecentsCurrentUser;
    private int mDraggingInRecentsCurrentUser;


@@ -162,6 +164,20 @@ public class Recents extends SystemUI
        }
        }
    };
    };



    private BroadcastReceiver mSystemUserUnlockedReceiver = new BroadcastReceiver() {
        @Override
        public void onReceive(Context context, Intent intent) {
            if (Intent.ACTION_USER_UNLOCKED.equals(intent.getAction())) {
                int userId = intent.getIntExtra(Intent.EXTRA_USER_HANDLE, UserHandle.USER_NULL);
                if (userId != UserHandle.USER_NULL) {
                    mImpl.onUserUnlocked(userId);
                }
            }
        }
    };


    /**
    /**
     * Returns the callbacks interface that non-system users can call.
     * Returns the callbacks interface that non-system users can call.
     */
     */
@@ -191,7 +207,7 @@ public class Recents extends SystemUI
        sSystemServicesProxy = SystemServicesProxy.getInstance(mContext);
        sSystemServicesProxy = SystemServicesProxy.getInstance(mContext);
        sTaskLoader = new RecentsTaskLoader(mContext);
        sTaskLoader = new RecentsTaskLoader(mContext);
        sConfiguration = new RecentsConfiguration(mContext);
        sConfiguration = new RecentsConfiguration(mContext);
        mHandler = new Handler();

        UiModeManager uiModeManager = (UiModeManager) mContext.
        UiModeManager uiModeManager = (UiModeManager) mContext.
                getSystemService(Context.UI_MODE_SERVICE);
                getSystemService(Context.UI_MODE_SERVICE);
        if (uiModeManager.getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION) {
        if (uiModeManager.getCurrentModeType() == Configuration.UI_MODE_TYPE_TELEVISION) {
@@ -221,6 +237,12 @@ public class Recents extends SystemUI
            // For the system user, initialize an instance of the interface that we can pass to the
            // For the system user, initialize an instance of the interface that we can pass to the
            // secondary user
            // secondary user
            mSystemToUserCallbacks = new RecentsSystemUser(mContext, mImpl);
            mSystemToUserCallbacks = new RecentsSystemUser(mContext, mImpl);

            // Listen for user-unlocked to kick off preloading recents
            IntentFilter filter = new IntentFilter();
            filter.addAction(Intent.ACTION_USER_UNLOCKED);
            mContext.registerReceiverAsUser(mSystemUserUnlockedReceiver, UserHandle.SYSTEM, filter,
                    null /* permission */, null /* scheduler */);
        } else {
        } else {
            // For the secondary user, bind to the primary user's service to get a persistent
            // For the secondary user, bind to the primary user's service to get a persistent
            // interface to register its implementation and to later update its state
            // interface to register its implementation and to later update its state
+5 −1
Original line number Original line Diff line number Diff line
@@ -186,7 +186,7 @@ public class RecentsImpl implements ActivityOptions.OnAnimationFinishedListener
        reloadResources();
        reloadResources();
    }
    }


    public void onBootCompleted() {
    public void onUserUnlocked(int userId) {
        // When we start, preload the data associated with the previous recent tasks.
        // When we start, preload the data associated with the previous recent tasks.
        // We can use a new plan since the caches will be the same.
        // We can use a new plan since the caches will be the same.
        RecentsTaskLoader loader = Recents.getTaskLoader();
        RecentsTaskLoader loader = Recents.getTaskLoader();
@@ -199,6 +199,10 @@ public class RecentsImpl implements ActivityOptions.OnAnimationFinishedListener
        loader.loadTasks(mContext, plan, launchOpts);
        loader.loadTasks(mContext, plan, launchOpts);
    }
    }


    public void onBootCompleted() {
        // Do nothing
    }

    public void onConfigurationChanged() {
    public void onConfigurationChanged() {
        reloadResources();
        reloadResources();
        mDummyStackView.reloadOnConfigurationChange();
        mDummyStackView.reloadOnConfigurationChange();