Android AppWidgetProvider应用

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);

    }

}


你可能感兴趣的:(Android AppWidgetProvider应用)