android之Widget开发详解

Android Widget开发案例实现是本文要介绍的内容,主要是来了解并学习Android Widget开发应用,今天我们要写一下Android Widget开发,由于快点凌晨,我就不说的太具体了,同志们就模仿吧!首先看一下效果图:

android之Widget开发详解_第1张图片


 
下面是Demo的详细步骤:

一、新建一个Android工程命名为:WidgetDemo.

二、准备素材,一个是Widget的图标,一个是Widget的背景。存放目录如下图:

android之Widget开发详解_第2张图片

三、修改string.xml文件如下:

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="utf-8"?>      
  2. <resources>      
  3.     <string name="hello">Hello World, WidetDemo!</string>      
  4.     <string name="app_name">DaysToWorldCup</string>      
  5. </resources>     

四、建立Widget内容提供者文件,我们在res下建立xml文件夹,并且新建一个widget_provider.xml代码入下:

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="utf-8"?>      
  2. <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"      
  3.     android:minWidth="50dip"      
  4.     android:minHeight="50dip"      
  5.     android:updatePeriodMillis="10000"      
  6.     android:initialLayout="@layout/main"/>      

其中宽度、长度很清楚,还有android:updatePeriodMillis是自动更新的时间间隔,android:initialLayout是Widget的界面描述文件。

还有一个属性Android:configure是可选的,如果你的Widget需要在启动时先启动一个Activity,则需要设定该项为你的Activity。

五、修改main.xml布局,代码如下:

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="utf-8"?>      
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"      
  3.     android:orientation="vertical"      
  4.     android:layout_width="fill_parent"      
  5.     android:layout_height="fill_parent"      
  6.     android:background="@drawable/wordcup"      
  7.     >      
  8. <TextView        
  9.     android:id="@+id/wordcup"      
  10.     android:layout_width="fill_parent"       
  11.     android:layout_height="wrap_content"       
  12.     android:text="@string/hello"      
  13.     android:textSize="12px"      
  14.     android:textColor="#ff0000"      
  15.     />      
  16. </LinearLayout>  

六、修改WidgetDemo.java代码如下:

[java]  view plain  copy
 print ?
  1. package com.android.tutor;      
  2. import java.util.Calendar;      
  3. import java.util.Date;      
  4. import java.util.GregorianCalendar;      
  5. import java.util.Timer;      
  6. import java.util.TimerTask;      
  7. import android.appwidget.AppWidgetManager;      
  8. import android.appwidget.AppWidgetProvider;      
  9. import android.content.ComponentName;      
  10. import android.content.Context;      
  11. import android.widget.RemoteViews;      
  12. public class WidetDemo extends AppWidgetProvider {      
  13.     /** Called when the activity is first created. */      
  14.         
  15.     @Override      
  16.     public void onUpdate(Context context, AppWidgetManager appWidgetManager,      
  17.             int[] appWidgetIds) {      
  18.               
  19.         Timer timer = new Timer();      
  20.         timer.scheduleAtFixedRate(new MyTime(context,appWidgetManager), 160000);      
  21.         super.onUpdate(context, appWidgetManager, appWidgetIds);      
  22.     }      
  23.           
  24.     private class MyTime extends TimerTask{      
  25.         RemoteViews remoteViews;      
  26.         AppWidgetManager appWidgetManager;      
  27.         ComponentName thisWidget;      
  28.               
  29.         public MyTime(Context context,AppWidgetManager appWidgetManager){      
  30.             this.appWidgetManager = appWidgetManager;      
  31.             remoteViews = new RemoteViews(context.getPackageName(),R.layout.main);      
  32.                   
  33.             thisWidget = new ComponentName(context,WidetDemo.class);      
  34.         }      
  35.         public void run() {      
  36.                   
  37.             Date date = new Date();      
  38.             Calendar calendar = new GregorianCalendar(2010,06,11);      
  39.             long days = (((calendar.getTimeInMillis()-date.getTime())/1000))/86400;      
  40.             remoteViews.setTextViewText(R.id.wordcup, "距离南非世界杯还有" + days+"天");      
  41.             appWidgetManager.updateAppWidget(thisWidget, remoteViews);      
  42.                   
  43.         }      
  44.     }      
  45. }     

七、修改配置文件AndroidManifest.xml,代码如下:

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="utf-8"?>      
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"      
  3.       package="com.android.tutor"      
  4.       android:versionCode="1"      
  5.       android:versionName="1.0">      
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name">      
  7.         <receiver android:name=".WidetDemo"      
  8.                   android:label="@string/app_name">      
  9.             <intent-filter>      
  10.                 <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />      
  11.             </intent-filter>      
  12.             <meta-data android:name="android.appwidget.provider"      
  13.                        android:resource="@xml/widget_provider"/>      
  14.         </receiver>      
  15.     </application>      
  16.     <uses-sdk android:minSdkVersion="7" />      
  17. </manifest>      

其中

[html]  view plain  copy
 print ?
  1. <receiver android:name=".WidetDemo"    android:label="@string/app_name">      

name指定该Widget的接收者是WidetDemo,即你建立的AppWidgetProvider子类,label指定该Widget的标签,还可以用属性icon指定图标

[html]  view plain  copy
 print ?
  1. <intent-filter>     
  2.  <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />   
  3.   </intent-filter>    


是采用android文档中提供的,用于接收更新的intent意图

[html]  view plain  copy
 print ?
  1. <meta-data android:name="android.appwidget.provider"    
  2. android:resource="@xml/widget_provider"/>   


resource指定该Widget的描述信息,该描述中定义了Widget的相关信息,如该Widget的宽度、长度、自动更新的间隔时间等信息,也就是前面四所定义的内容

八、点击运行(Ctrl+F11),之,运行成功后,我们长时间点击桌面,会出现如下俩个,依次点击,就可以看到最上面的效果图:

android之Widget开发详解_第3张图片 android之Widget开发详解_第4张图片

你可能感兴趣的:(android之Widget开发详解)