package com.android.launcher3.model; import android.content.Context; import android.content.pm.ActivityInfo; import com.android.launcher3.InvariantDeviceProfile; import com.android.launcher3.Utilities; import com.android.launcher3.icons.BitmapInfo; import com.android.launcher3.icons.IconCache; import com.android.launcher3.pm.ShortcutConfigActivityInfo; import com.android.launcher3.util.ComponentKey; import com.android.launcher3.widget.LauncherAppWidgetProviderInfo; /** * An wrapper over various items displayed in a widget picker, * {@link LauncherAppWidgetProviderInfo} & {@link ActivityInfo}. This provides easier access to * common attributes like spanX and spanY. */ public class WidgetItem extends ComponentKey { public final LauncherAppWidgetProviderInfo widgetInfo; public final ShortcutConfigActivityInfo activityInfo; public BitmapInfo bitmap = BitmapInfo.LOW_RES_INFO; public final String label; public final CharSequence description; public final int spanX, spanY; public WidgetItem(LauncherAppWidgetProviderInfo info, InvariantDeviceProfile idp, IconCache iconCache, Context context) { super(info.provider, info.getProfile()); label = iconCache.getTitleNoCache(info); description = info.loadDescription(context); widgetInfo = info; activityInfo = null; spanX = Math.min(info.spanX, idp.numColumns); spanY = Math.min(info.spanY, idp.numRows); } public WidgetItem(ShortcutConfigActivityInfo info, IconCache iconCache) { super(info.getComponent(), info.getUser()); label = info.isPersistable() ? iconCache.getTitleNoCache(info) : Utilities.trim(info.getLabel()); description = null; widgetInfo = null; activityInfo = info; spanX = spanY = 1; } /** * Returns {@code true} if this {@link WidgetItem} has the same type as the given * {@code otherItem}. * * For example, both items are widgets or both items are shortcuts. */ public boolean hasSameType(WidgetItem otherItem) { if (widgetInfo != null && otherItem.widgetInfo != null) { return true; } if (activityInfo != null && otherItem.activityInfo != null) { return true; } return false; } /** Returns whether this {@link WidgetItem} is for a shortcut rather than an app widget. */ public boolean isShortcut() { return activityInfo != null; } }