mirror of
https://github.com/LawnchairLauncher/lawnchair.git
synced 2026-03-02 08:56:55 +00:00
This allows for smooth animations as the items will have their full height resolved Bug: 190892517 Test: verified locally Test: CachingWidgetPreviewLoaderTest Change-Id: I86afc6951a4cc82ae45e63795791d259a3bb3cda
78 lines
2.7 KiB
Java
78 lines
2.7 KiB
Java
package com.android.launcher3.model;
|
|
|
|
import static com.android.launcher3.Utilities.ATLEAST_S;
|
|
|
|
import android.annotation.SuppressLint;
|
|
import android.content.pm.ActivityInfo;
|
|
import android.content.pm.PackageManager;
|
|
import android.content.res.Resources;
|
|
|
|
import com.android.launcher3.InvariantDeviceProfile;
|
|
import com.android.launcher3.Utilities;
|
|
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 final String label;
|
|
public final int spanX, spanY;
|
|
|
|
public WidgetItem(LauncherAppWidgetProviderInfo info,
|
|
InvariantDeviceProfile idp, IconCache iconCache) {
|
|
super(info.provider, info.getProfile());
|
|
|
|
label = iconCache.getTitleNoCache(info);
|
|
widgetInfo = info;
|
|
activityInfo = null;
|
|
|
|
spanX = Math.min(info.spanX, idp.numColumns);
|
|
spanY = Math.min(info.spanY, idp.numRows);
|
|
}
|
|
|
|
public WidgetItem(ShortcutConfigActivityInfo info, IconCache iconCache, PackageManager pm) {
|
|
super(info.getComponent(), info.getUser());
|
|
label = info.isPersistable() ? iconCache.getTitleNoCache(info) :
|
|
Utilities.trim(info.getLabel(pm));
|
|
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} has a preview layout that can be used. */
|
|
@SuppressLint("NewApi") // Already added API check.
|
|
public boolean hasPreviewLayout() {
|
|
return ATLEAST_S && widgetInfo != null && widgetInfo.previewLayout != Resources.ID_NULL;
|
|
}
|
|
|
|
/** Returns whether this {@link WidgetItem} is for a shortcut rather than an app widget. */
|
|
public boolean isShortcut() {
|
|
return activityInfo != null;
|
|
}
|
|
}
|