Merge "Count app launch correctly." into pi-dev

This commit is contained in:
TreeHugger Robot
2018-05-17 02:12:23 +00:00
committed by Android (Google) Code Review
3 changed files with 37 additions and 7 deletions

View File

@@ -17,6 +17,7 @@
package com.android.systemui.shared.system; package com.android.systemui.shared.system;
import android.app.ActivityManager.TaskSnapshot; import android.app.ActivityManager.TaskSnapshot;
import android.content.ComponentName;
import android.os.UserHandle; import android.os.UserHandle;
import android.util.Log; import android.util.Log;
@@ -43,6 +44,7 @@ public abstract class TaskStackChangeListener {
public void onActivityDismissingDockedStack() { } public void onActivityDismissingDockedStack() { }
public void onActivityLaunchOnSecondaryDisplayFailed() { } public void onActivityLaunchOnSecondaryDisplayFailed() { }
public void onTaskProfileLocked(int taskId, int userId) { } public void onTaskProfileLocked(int taskId, int userId) { }
public void onTaskCreated(int taskId, ComponentName componentName) { }
public void onTaskRemoved(int taskId) { } public void onTaskRemoved(int taskId) { }
public void onTaskMovedToFront(int taskId) { } public void onTaskMovedToFront(int taskId) { }
public void onActivityRequestedOrientationChanged(int taskId, int requestedOrientation) { } public void onActivityRequestedOrientationChanged(int taskId, int requestedOrientation) { }

View File

@@ -19,6 +19,7 @@ package com.android.systemui.shared.system;
import android.app.ActivityManager.TaskSnapshot; import android.app.ActivityManager.TaskSnapshot;
import android.app.IActivityManager; import android.app.IActivityManager;
import android.app.TaskStackListener; import android.app.TaskStackListener;
import android.content.ComponentName;
import android.os.Handler; import android.os.Handler;
import android.os.Looper; import android.os.Looper;
import android.os.Message; import android.os.Message;
@@ -140,11 +141,15 @@ public class TaskStackChangeListeners extends TaskStackListener {
} }
@Override @Override
public void onTaskSnapshotChanged(int taskId, TaskSnapshot snapshot) public void onTaskSnapshotChanged(int taskId, TaskSnapshot snapshot) throws RemoteException {
throws RemoteException {
mHandler.obtainMessage(H.ON_TASK_SNAPSHOT_CHANGED, taskId, 0, snapshot).sendToTarget(); mHandler.obtainMessage(H.ON_TASK_SNAPSHOT_CHANGED, taskId, 0, snapshot).sendToTarget();
} }
@Override
public void onTaskCreated(int taskId, ComponentName componentName) throws RemoteException {
mHandler.obtainMessage(H.ON_TASK_CREATED, taskId, 0, componentName).sendToTarget();
}
@Override @Override
public void onTaskRemoved(int taskId) throws RemoteException { public void onTaskRemoved(int taskId) throws RemoteException {
mHandler.obtainMessage(H.ON_TASK_REMOVED, taskId, 0).sendToTarget(); mHandler.obtainMessage(H.ON_TASK_REMOVED, taskId, 0).sendToTarget();
@@ -174,9 +179,10 @@ public class TaskStackChangeListeners extends TaskStackListener {
private static final int ON_PINNED_STACK_ANIMATION_STARTED = 9; private static final int ON_PINNED_STACK_ANIMATION_STARTED = 9;
private static final int ON_ACTIVITY_UNPINNED = 10; private static final int ON_ACTIVITY_UNPINNED = 10;
private static final int ON_ACTIVITY_LAUNCH_ON_SECONDARY_DISPLAY_FAILED = 11; private static final int ON_ACTIVITY_LAUNCH_ON_SECONDARY_DISPLAY_FAILED = 11;
private static final int ON_TASK_REMOVED = 12; private static final int ON_TASK_CREATED = 12;
private static final int ON_TASK_MOVED_TO_FRONT = 13; private static final int ON_TASK_REMOVED = 13;
private static final int ON_ACTIVITY_REQUESTED_ORIENTATION_CHANGE = 14; private static final int ON_TASK_MOVED_TO_FRONT = 14;
private static final int ON_ACTIVITY_REQUESTED_ORIENTATION_CHANGE = 15;
public H(Looper looper) { public H(Looper looper) {
@@ -262,6 +268,13 @@ public class TaskStackChangeListeners extends TaskStackListener {
} }
break; break;
} }
case ON_TASK_CREATED: {
for (int i = mTaskStackListeners.size() - 1; i >= 0; i--) {
mTaskStackListeners.get(i).onTaskCreated(msg.arg1,
(ComponentName) msg.obj);
}
break;
}
case ON_TASK_REMOVED: { case ON_TASK_REMOVED: {
for (int i = mTaskStackListeners.size() - 1; i >= 0; i--) { for (int i = mTaskStackListeners.size() - 1; i >= 0; i--) {
mTaskStackListeners.get(i).onTaskRemoved(msg.arg1); mTaskStackListeners.get(i).onTaskRemoved(msg.arg1);

View File

@@ -33,6 +33,7 @@ import android.annotation.StringRes;
import android.annotation.TargetApi; import android.annotation.TargetApi;
import android.app.ActivityManager; import android.app.ActivityManager;
import android.content.BroadcastReceiver; import android.content.BroadcastReceiver;
import android.content.ComponentName;
import android.content.Context; import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.IntentFilter; import android.content.IntentFilter;
@@ -63,7 +64,6 @@ import com.android.systemui.R;
import com.android.systemui.recents.misc.SysUiTaskStackChangeListener; import com.android.systemui.recents.misc.SysUiTaskStackChangeListener;
import com.android.systemui.shared.recents.IOverviewProxy; import com.android.systemui.shared.recents.IOverviewProxy;
import com.android.systemui.shared.system.ActivityManagerWrapper; import com.android.systemui.shared.system.ActivityManagerWrapper;
import com.android.systemui.shared.system.LauncherEventUtil;
import java.util.Collections; import java.util.Collections;
import java.util.HashSet; import java.util.HashSet;
@@ -110,8 +110,19 @@ public class RecentsOnboarding {
private int mOverviewOpenedCountSinceQuickScrubTipDismiss; private int mOverviewOpenedCountSinceQuickScrubTipDismiss;
private final SysUiTaskStackChangeListener mTaskListener = new SysUiTaskStackChangeListener() { private final SysUiTaskStackChangeListener mTaskListener = new SysUiTaskStackChangeListener() {
private String mLastPackageName;
@Override @Override
public void onTaskStackChanged() { public void onTaskCreated(int taskId, ComponentName componentName) {
onAppLaunch();
}
@Override
public void onTaskMovedToFront(int taskId) {
onAppLaunch();
}
private void onAppLaunch() {
ActivityManager.RunningTaskInfo info = ActivityManagerWrapper.getInstance() ActivityManager.RunningTaskInfo info = ActivityManagerWrapper.getInstance()
.getRunningTask(ACTIVITY_TYPE_UNDEFINED /* ignoreActivityType */); .getRunningTask(ACTIVITY_TYPE_UNDEFINED /* ignoreActivityType */);
if (info == null) { if (info == null) {
@@ -121,6 +132,10 @@ public class RecentsOnboarding {
hide(true); hide(true);
return; return;
} }
if (info.baseActivity.getPackageName().equals(mLastPackageName)) {
return;
}
mLastPackageName = info.baseActivity.getPackageName();
int activityType = info.configuration.windowConfiguration.getActivityType(); int activityType = info.configuration.windowConfiguration.getActivityType();
if (activityType == ACTIVITY_TYPE_STANDARD) { if (activityType == ACTIVITY_TYPE_STANDARD) {
boolean alreadySeenSwipeUpOnboarding = hasSeenSwipeUpOnboarding(); boolean alreadySeenSwipeUpOnboarding = hasSeenSwipeUpOnboarding();