From 78403feedcf6d61a527cf0c904cb55ca43c0f3cb Mon Sep 17 00:00:00 2001 From: Winson Chung Date: Fri, 21 Jan 2011 15:38:02 -0800 Subject: Changing downloads tab to my apps and making most recent first. (3377455) Change-Id: I75ae46ad601457ecfc9555aff7f7ff5284440317 --- src/com/android/launcher2/AllAppsPagedView.java | 1 + src/com/android/launcher2/ApplicationInfo.java | 10 +++++++++- src/com/android/launcher2/LauncherModel.java | 8 ++++++++ 3 files changed, 18 insertions(+), 1 deletion(-) (limited to 'src/com/android') diff --git a/src/com/android/launcher2/AllAppsPagedView.java b/src/com/android/launcher2/AllAppsPagedView.java index fe7312d69..59065996e 100644 --- a/src/com/android/launcher2/AllAppsPagedView.java +++ b/src/com/android/launcher2/AllAppsPagedView.java @@ -314,6 +314,7 @@ public class AllAppsPagedView extends PagedViewWithDraggableItems implements All filteredApps.add(info); } } + Collections.sort(filteredApps, LauncherModel.APP_INSTALL_TIME_COMPARATOR); } return filteredApps; } diff --git a/src/com/android/launcher2/ApplicationInfo.java b/src/com/android/launcher2/ApplicationInfo.java index 0851cd350..3adea373e 100644 --- a/src/com/android/launcher2/ApplicationInfo.java +++ b/src/com/android/launcher2/ApplicationInfo.java @@ -52,6 +52,11 @@ class ApplicationInfo extends ItemInfo { */ Bitmap iconBitmap; + /** + * The time at which the app was first installed. + */ + long firstInstallTime; + ComponentName componentName; static final int APP_FLAG = 1; @@ -82,6 +87,7 @@ class ApplicationInfo extends ItemInfo { if ((appFlags & android.content.pm.ApplicationInfo.FLAG_UPDATED_SYSTEM_APP) != 0) { flags |= DOWNLOADED_FLAG; } + firstInstallTime = pm.getPackageInfo(packageName, 0).firstInstallTime; // TODO: Figure out how to determine what is a game // If it's not a game, it's an app @@ -101,6 +107,7 @@ class ApplicationInfo extends ItemInfo { title = info.title.toString(); intent = new Intent(info.intent); flags = info.flags; + firstInstallTime = info.firstInstallTime; } /** @@ -128,7 +135,8 @@ class ApplicationInfo extends ItemInfo { Log.d(tag, label + " size=" + list.size()); for (ApplicationInfo info: list) { Log.d(tag, " title=\"" + info.title + "\" titleBitmap=" + info.titleBitmap - + " iconBitmap=" + info.iconBitmap); + + " iconBitmap=" + info.iconBitmap + " firstInstallTime=" + + info.firstInstallTime); } } diff --git a/src/com/android/launcher2/LauncherModel.java b/src/com/android/launcher2/LauncherModel.java index 7e7261038..005273749 100644 --- a/src/com/android/launcher2/LauncherModel.java +++ b/src/com/android/launcher2/LauncherModel.java @@ -1747,6 +1747,14 @@ public class LauncherModel extends BroadcastReceiver { return sCollator.compare(a.title.toString(), b.title.toString()); } }; + public static final Comparator APP_INSTALL_TIME_COMPARATOR + = new Comparator() { + public final int compare(ApplicationInfo a, ApplicationInfo b) { + if (a.firstInstallTime < b.firstInstallTime) return 1; + if (a.firstInstallTime > b.firstInstallTime) return -1; + return 0; + } + }; public void dumpState() { Log.d(TAG, "mCallbacks=" + mCallbacks); -- cgit v1.2.3