summaryrefslogtreecommitdiffstats
path: root/src/com/android/launcher3/widget/WidgetsListAdapter.java
diff options
context:
space:
mode:
authorHyunyoung Song <hyunyoungs@google.com>2016-02-22 16:36:15 -0800
committerHyunyoung Song <hyunyoungs@google.com>2016-02-22 16:36:15 -0800
commit72a9953cf463e0e7a8d24903f1692828ffe5b017 (patch)
treeacfe28f7974788e9b00a5dcadf6233b18bfd09f1 /src/com/android/launcher3/widget/WidgetsListAdapter.java
parentfbf19cccd293ca23cbed38eaa25abc6ea72be83e (diff)
downloadandroid_packages_apps_Trebuchet-72a9953cf463e0e7a8d24903f1692828ffe5b017.tar.gz
android_packages_apps_Trebuchet-72a9953cf463e0e7a8d24903f1692828ffe5b017.tar.bz2
android_packages_apps_Trebuchet-72a9953cf463e0e7a8d24903f1692828ffe5b017.zip
Load label in bg thread to prevent ANR
b/27238970 Change-Id: Ic5d77df7d5276cee07861d59427a94fb19691d9c
Diffstat (limited to 'src/com/android/launcher3/widget/WidgetsListAdapter.java')
-rw-r--r--src/com/android/launcher3/widget/WidgetsListAdapter.java19
1 files changed, 6 insertions, 13 deletions
diff --git a/src/com/android/launcher3/widget/WidgetsListAdapter.java b/src/com/android/launcher3/widget/WidgetsListAdapter.java
index ac9d62e9a..55a2f7a34 100644
--- a/src/com/android/launcher3/widget/WidgetsListAdapter.java
+++ b/src/com/android/launcher3/widget/WidgetsListAdapter.java
@@ -16,9 +16,7 @@
package com.android.launcher3.widget;
import android.annotation.TargetApi;
-import android.content.Context;
import android.content.pm.ResolveInfo;
-import android.content.res.Resources;
import android.os.Build;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.RecyclerView.Adapter;
@@ -30,7 +28,6 @@ import android.view.ViewGroup.LayoutParams;
import android.widget.LinearLayout;
import com.android.launcher3.BubbleTextView;
-import com.android.launcher3.DeviceProfile;
import com.android.launcher3.Launcher;
import com.android.launcher3.LauncherAppState;
import com.android.launcher3.LauncherAppWidgetProviderInfo;
@@ -136,17 +133,13 @@ public class WidgetsListAdapter extends Adapter<WidgetsRowViewHolder> {
}
for (int i=0; i < infoList.size(); i++) {
WidgetCell widget = (WidgetCell) row.getChildAt(i);
- if (infoList.get(i) instanceof LauncherAppWidgetProviderInfo) {
- LauncherAppWidgetProviderInfo info = (LauncherAppWidgetProviderInfo) infoList.get(i);
- PendingAddWidgetInfo pawi = new PendingAddWidgetInfo(mLauncher, info, null);
- widget.setTag(pawi);
- widget.applyFromAppWidgetProviderInfo(info, mWidgetPreviewLoader);
- } else if (infoList.get(i) instanceof ResolveInfo) {
- ResolveInfo info = (ResolveInfo) infoList.get(i);
- PendingAddShortcutInfo pasi = new PendingAddShortcutInfo(info.activityInfo);
- widget.setTag(pasi);
- widget.applyFromResolveInfo(mLauncher.getPackageManager(), info, mWidgetPreviewLoader);
+ Object info = infoList.get(i);
+ if (info instanceof LauncherAppWidgetProviderInfo) {
+ widget.setTag(new PendingAddWidgetInfo(mLauncher, (LauncherAppWidgetProviderInfo)info, null));
+ } else if (info instanceof ResolveInfo) {
+ widget.setTag(new PendingAddShortcutInfo(((ResolveInfo) info).activityInfo));
}
+ widget.applyFromInfo(info, mWidgetsModel.getLabel(info), mWidgetPreviewLoader);
widget.ensurePreview();
widget.setVisibility(View.VISIBLE);
}