Szukaj…


Uwagi

SDv

Deklaracja manifestu -

Zadeklaruj klasę AppWidgetProvider w pliku AndroidManifest.xml aplikacji. Na przykład:

<receiver android:name="ExampleAppWidgetProvider" >
<intent-filter>
    <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<meta-data android:name="android.appwidget.provider"
           android:resource="@xml/example_appwidget_info" />
</receiver>

Metadane

Dodaj metadane AppWidgetProviderInfo w res/xml :

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:minWidth="40dp"
    android:minHeight="40dp"
    android:updatePeriodMillis="86400000"
    android:previewImage="@drawable/preview"
    android:initialLayout="@layout/example_appwidget"
    android:configure="com.example.android.ExampleAppWidgetConfigure"
    android:resizeMode="horizontal|vertical"
    android:widgetCategory="home_screen">
</appwidget-provider>

Klasa AppWidgetProvider

Najważniejszym wywołaniem zwrotnym AppWidgetProvider jest onUpdate() . Nazywa się to za każdym razem, gdy dodawany jest widget.

public class ExampleAppWidgetProvider extends AppWidgetProvider {

    public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
        final int N = appWidgetIds.length;

        // Perform this loop procedure for each App Widget that belongs to this provider
        for (int i=0; i<N; i++) {
            int appWidgetId = appWidgetIds[i];

            // Create an Intent to launch ExampleActivity
            Intent intent = new Intent(context, ExampleActivity.class);
            PendingIntent pendingIntent = PendingIntent.getActivity(context, 0, intent, 0);

            // Get the layout for the App Widget and attach an on-click listener
            // to the button
            RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.appwidget_provider_layout);
            views.setOnClickPendingIntent(R.id.button, pendingIntent);

            // Tell the AppWidgetManager to perform an update on the current app widget
            appWidgetManager.updateAppWidget(appWidgetId, views);
        }
    }
}

onAppWidgetOptionsChanged() jest wywoływana po umieszczeniu lub zmianie rozmiaru widżetu.

onDeleted(Context, int[]) jest wywoływany po usunięciu widżetu.

Dwa widżety z różnymi deklaracjami układu

  1. Zadeklaruj dwa odbiorniki w pliku manifestu:
<receiver
    android:name=".UVMateWidget"
    android:label="UVMate Widget 1x1">
    <intent-filter>
        <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
    </intent-filter>

    <meta-data
        android:name="android.appwidget.provider"
        android:resource="@xml/widget_1x1" />
</receiver>
<receiver
    android:name=".UVMateWidget2x2"
    android:label="UVMate Widget 2x2">
    <intent-filter>
        <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
    </intent-filter>

    <meta-data
        android:name="android.appwidget.provider"
        android:resource="@xml/widget_2x2" />
</receiver>
  1. Utwórz dwa układy
    • @xml/widget_1x1
    • @xml/widget_2x2
  2. Zadeklaruj podklasę UVMateWidget2x2 z klasy UVMateWidget o rozszerzonym zachowaniu:
package au.com.aershov.uvmate;

import android.content.Context;
import android.widget.RemoteViews;

public class UVMateWidget2x2 extends UVMateWidget {

    public RemoteViews getRemoteViews(Context context, int minWidth,
                                      int minHeight) {

        mUVMateHelper.saveWidgetSize(mContext.getString(R.string.app_ws_2x2));
        return new RemoteViews(context.getPackageName(), R.layout.widget_2x2);
    }
}

Utwórz / zintegruj podstawowy widget za pomocą Android Studio

Najnowsze Android Studio utworzy i zintegruje podstawowy widget do aplikacji w 2 krokach.

Bezpośrednio na Twojej aplikacji ==> Nowy ==> Widżet ==> Widżet aplikacji

.

wprowadź opis zdjęcia tutaj

Wyświetli się ekran jak poniżej i wypełni pola

wprowadź opis zdjęcia tutaj

Zrobione.

Stworzy i zintegruje z aplikacją podstawowy widget HelloWorld (w tym plik układu, plik metadanych, deklarację w pliku manifestu itp.).



Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow