Wykrywalność widżetu

Na urządzeniach z Androidem 8.0 (poziom interfejsu API 26) lub nowszym programy uruchamiające, które umożliwiają użytkownikom tworzenie przypiętych skrótów pozwalają też przypinać widżety do ekranu głównego. Podobnie jak przypięte skróty, te przypięte widżety umożliwiają użytkownikom dostęp do określonych zadań w aplikacji i można je dodawać do ekranu głównego bezpośrednio z aplikacji, jak pokazano w tym filmie.

Przykład układu elastycznego
Rysunek 2. Przykład przypinania widżetu.

Umożliwianie użytkownikom przypinania widżetu

W aplikacji możesz utworzyć prośbę o przypięcie widżetu do obsługiwanego programu uruchamiającego. Aby to zrobić, wykonaj te czynności:

  1. Upewnij się, że deklarujesz widżet w pliku manifestu aplikacji.

  2. Wywołaj metodę requestPinAppWidget(), jak pokazano w tym fragmencie kodu:

Kotlin

val appWidgetManager = AppWidgetManager.getInstance(context)
val myProvider = ComponentName(context, ExampleAppWidgetProvider::class.java)

if (appWidgetManager.isRequestPinAppWidgetSupported()) {
    // Create the PendingIntent object only if your app needs to be notified
    // when the user chooses to pin the widget. Note that if the pinning
    // operation fails, your app isn't notified. This callback receives the ID
    // of the newly pinned widget (EXTRA_APPWIDGET_ID).
    val successCallback = PendingIntent.getBroadcast(
            /* context = */ context,
            /* requestCode = */ 0,
            /* intent = */ Intent(...),
            /* flags = */ PendingIntent.FLAG_UPDATE_CURRENT)

    appWidgetManager.requestPinAppWidget(myProvider, null, successCallback)
}

Java

AppWidgetManager appWidgetManager = AppWidgetManager.getInstance(context);
ComponentName myProvider = new ComponentName(context, ExampleAppWidgetProvider.class);

if (appWidgetManager.isRequestPinAppWidgetSupported()) {
    // Create the PendingIntent object only if your app needs to be notified
    // when the user chooses to pin the widget. Note that if the pinning
    // operation fails, your app isn't notified. This callback receives the ID
    // of the newly pinned widget (EXTRA_APPWIDGET_ID).
    PendingIntent successCallback = PendingIntent.getBroadcast(
            /* context = */ context,
            /* requestCode = */ 0,
            /* intent = */ new Intent(...),
            /* flags = */ PendingIntent.FLAG_UPDATE_CURRENT);

    appWidgetManager.requestPinAppWidget(myProvider, null, successCallback);
}

Użytkownicy odkrywają i dodają Twój widżet za pomocą selektora widżetów lub z poziomu aplikacji, gdy funkcje widżetu są najbardziej przydatne. Więcej informacji znajdziesz w artykule Odkrywanie i promocja.