需要创建三个XML文件以及一个Class文件
三个XML文件分别是
- Widget布局文件
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@android:color/white"><TextViewandroid:id="@+id/textView"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="Hello, Widget!"android:textSize="20sp" />
</RelativeLayout>
- WidgetInfoProvider文件
<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"android:minWidth="40dp"android:minHeight="40dp"android:updatePeriodMillis="86400000"android:initialLayout="@layout/widght_layout"android:resizeMode="horizontal|vertical"android:widgetCategory="home_screen|keyguard"android:previewImage="@drawable/ic_launcher_background" />
- AndroidMainfest文件
3.1 在receiver标签下,添加广播的Action
3.2 在meta-data标签下,表明这个广播接收器是一个原生Widget,并加载原生Widget配置文件
<receiverandroid:name=".MyTimeWidget"android:exported="true"><intent-filter><action android:name="android.appwidget.action.APPWIDGET_UPDATE" /><action android:name="com.ljheee.widget.UPDATE_TIME" /></intent-filter><meta-dataandroid:name="android.appwidget.provider"android:resource="@xml/my_time_widget_info" /></receiver>
4.继承AppWidgetProvider(实际上是一个广播接收器)
public class MyWidget extends AppWidgetProvider {@Overridepublic void onEnabled(Context context) {super.onEnabled(context);// 在第一个 Widget 实例添加到桌面时调用}@Overridepublic void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {super.onUpdate(context, appWidgetManager, appWidgetIds);final int N = appWidgetIds.length;for (int i = 0; i < N; i++) {int appWidgetId = appWidgetIds[i];// 创建 RemoteViews 对象,用于更新 Widget 布局RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.widght_layout);// 在这里可以对 RemoteViews 进行更多的操作,例如设置文本、图片等// 创建一个 Intent,用于点击事件Intent intent = new Intent(context, MyWidget.class);intent.setAction("com.example.myapp.ACTION_CLICK");PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);// 更新 WidgetappWidgetManager.updateAppWidget(appWidgetId, views);}}@Overridepublic void onDisabled(Context context) {super.onDisabled(context);// 在最后一个 Widget 实例从桌面移除时调用}@Overridepublic void onRestored(Context context, int[] oldWidgetIds, int[] newWidgetIds) {super.onRestored(context, oldWidgetIds, newWidgetIds);}@Overridepublic void onDeleted(Context context, int[] appWidgetIds) {super.onDeleted(context, appWidgetIds);// 当 Widget 被删除时调用}@Overridepublic void onReceive(Context context, Intent intent) {super.onReceive(context, intent);// 接收广播消息,可以处理 Widget 的点击等事件if (intent.getAction().equals("com.example.myapp.ACTION_CLICK")) {// 处理点击事件// 可以在此处添加相应的逻辑,如更新 Widget 内容或执行其他操作}}
}