AppWidgetProvider 用来在HOME页面显示插件
实现步调:
1、为AppWidget供给一个元布局文件AppWigdetProvider_Provider.xml,用来显示Widget的界面。
2、创建一个类持续自AppWidgetProvider,并覆写里面的相干的办法。
3、为WidgetProvider创建一个引用的布局文件,或者直接用main.xml。
4、在法度中注册Manifest.xml。
代码如下:
1、在res/xml/文件夹下创建AppWigdetProvider_Provider.xml文件
<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
android:initialLayout="@layout/main" <!-- android:initialLayout 设置引用的布局文件 -->
android:minHeight="50dip"
android:minWidth="50dip"
android:PeriodMillis="5000" > <!-- 设置更新时候,单位为毫秒 -->
</appwidget-provider>
2、批改MainActivity持续自AppWidgetProvider并覆写里面的一些办法
public class MainActivity extends AppWidgetProvider { @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { super.onUpdate(context, appWidgetManager, appWidgetIds); Timer timer = new Timer(); timer.scheduleAtFixedRate(new LYTimeTask(context, appWidgetManager), 1, 50000); } private class LYTimeTask extends TimerTask { RemoteViews remoteViews; AppWidgetManager appWidgetManager; ComponentName widget; @Override public void run() { Date date = new Date(); Calendar calendar = new GregorianCalendar(2013, 07, 24); long days = (calendar.getTimeInMillis() - date.getTime()) / 1000 / 86400; remoteViews.setTextViewText(R.id.worldcup, "间隔宝贝诞辰" + days + "天"); appWidgetManager.AppWidget(widget, remoteViews); } public LYTimeTask(Context context, AppWidgetManager appWidgetManger) { super(); this.appWidgetManager = appWidgetManger; remoteViews = new RemoteViews(context.getPackageName(), R.layout.activity_main); widget = new ComponentName(context, MainActivity.class); } }; }
3、为Widget创建一个显示用的布局文件:main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/worldcup"
android:orientation="vertical" >
<TextView
android:id="@+id/babybirthday"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/message"
android:textSize="12px"
android:textColor="#ff0000" />
</LinearLayout>
4、批改法度主动生成的清单文件。
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<receiver
android:name=".MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" /><!--广播接管过滤器-->
</intent-filter>
<meta-data
android:name="android.appwidget.provider"
android:resource="@xml/AppWigdetProvider_Provider" /><!--AppWidgetProvider引用的Provider文件-->
</receiver>
</application>
运行法度:进入WIDGETS页面,可将Widget添加到HOME页
在AppWidgetProvider类中,还有其它相干的办法
public class WidgetProvider extends AppWidgetProvider { // 每接管一次广播消息就调用一次,应用频繁 public void onReceive(Context context, Intent intent) { super.onReceive(context, intent); } // 每次更新都调用一次该办法,应用频繁 public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { super.onUpdate(context, appWidgetManager, appWidgetIds); } // 每删除一个就调用一次 public void onDeleted(Context context, int[] appWidgetIds) { super.onDeleted(context, appWidgetIds); } // 当该Widget第一次添加到桌面是调用该办法,可添加多次但只第一次调用 public void onEnabled(Context context) { super.onEnabled(context); } // 当最后一个该Widget删除是调用该办法,重视是最后一个 public void onDisabled(Context context) { super.onDisabled(context); } }