Android Widget开发详解

移动开发
Android Widget开发详解是本文要介绍的内容,本例是为了实现一个手机Android平台的Widget开发,该Widget中的内容是根据输入账号从叽歪网站上获得得。

Android Widget开发详解是本文要介绍的内容,主要是来了解并学习Widget开发的概念,本例是为了实现一个手机Android平台的Widget开发,该Widget中的内容是根据输入账号从叽歪网站上获得得。当然,这个过程需要叽歪的API,得到信息后进行处理并显示出来。大体流程就是这样。好了,进入***步。

1、该叽歪账号是测试账号,用户名是“students”,密码是“111111”请不要擅自更改。

2、建立一个Widget

Androidreference中有关于如何建立一个Widget的详细方法,这里简要说明一下,详情可以查看AndroidSDK中自带的reference。

要建立一个Widget开发程序,分为如下几个步骤:

(1)创建一个类,让其继承类AppWidgetProvider,在AppWidgetProvider中有许多方法,例如onDelete(Context,int[]),onEnable(Context)等,但一般情况下我们只是覆写onUpdate(Context,AppWidgetManager,int[])方法。在该方法中,我们启动后台服务的类,一般是启动Thread类或者Android中的Service类。在该类中我们进行从服务器端获得数据并进行处理并在Widget中显示。

(2)在你的AndroidMenifest.xml中添加一个receiver标签,让其指向你的AppWidgetProvider子类。内容如下:

<receiver android:name="JiwaiWidget"     
    android:label="@string/app_name"     
    android:icon="@drawable/jiwai">     
    <intent-filter>     
    <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>     
    </intent-filter>     
    <meta-data android:name="android.appwidget.provider"     
    android:resource="@xml/info"/>     
    </receiver>     
<receiver android:name="JiwaiWidget"   
    android:label="@string/app_name"   
    android:icon="@drawable/jiwai">   
    <intent-filter>   
    <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/>   
    </intent-filter>   
    <meta-data android:name="android.appwidget.provider"   
    android:resource="@xml/info"/>   
    </receiver>  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.

对上面的代码进行解释:

***行指定该Widget开发的接收者是JiwaiWidget,即你建立的AppWidgetProvider子类;

第二行指定该Widget的标签名称,值为value目录下string.xml中的app_name值;

第三行指定该Widget开发的图标,值为drawable目录下jiwai图片;

第四行-第六行是采用Android文档中提供的;

第七行指定该Widget的描述者信息,该描述着中定义了Widget的相关信息,如该Widget的宽度、长度、自动更新的间隔时间等信息,该描述位于xml目录下的info.xml中。

(3)编写你的Widget的provider文件信息(本例中是xml/info.xml)

<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"     
    android:minWidth="200dp"     
    android:minHeight="90dp"     
    android:updatePeriodMillis="43200000"     
    android:initialLayout="@layout/appwidget"     
    android:configure="com.lawrenst.jiwai.JiwaiConfigure">     
    </appwidget-provider>     
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"   
    android:minWidth="200dp"   
    android:minHeight="90dp"   
    android:updatePeriodMillis="43200000"   
    android:initialLayout="@layout/appwidget"   
    android:configure="com.lawrenst.jiwai.JiwaiConfigure">   
    </appwidget-provider>  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.

其中android:updatePeriodMillis是自动更新的时间间隔,android:initialLayout是Widget的界面描述文件。Android:configure是可选的,如果你的Widget需要在启动时先启动一个Activity,则需要设定该项为你的Activity。本例中,需要你的嘀咕帐号和密码,所以应先显示一个Activity,输入你的账号和密码,然后将得到的信息在你的Widget中显示。

(4)在layout目录下编写appwidget.xml文件,配置你的Widget的界面信息:

<?xml version="1.0" encoding="UTF-8"?>     
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     
    android:layout_width="fill_parent"     
    android:layout_height="wrap_content"     
    android:orientation="vertical"     
    android:id="@+id/widget"     
    android:background="@drawable/title_a">     
    <LinearLayout android:layout_width="fill_parent"     
    android:orientation="horizontal"     
    android:layout_height="wrap_content"     
    android:background="@drawable/title">     
    <TextView android:id="@+id/username_display"     
    android:textStyle="bold"     
    android:layout_width="wrap_content"     
    android:layout_height="fill_parent"     
    android:textColor="#ffffff"     
    android:textSize="15px"     
    android:gravity="left|center_vertical"     
    android:paddingLeft="6px"/>     
    </LinearLayout>     
    <LinearLayout android:orientation="vertical"     
    android:layout_width="fill_parent"     
    android:layout_height="fill_parent">     
         
    <TextView android:id="@+id/text1"     
    android:layout_width="fill_parent"     
    android:textColor="#ffffff"     
    android:textSize="12px"     
    android:gravity="center_vertical|left"     
    android:paddingLeft="6px"     
    android:layout_height="30px">     
    </TextView>     
         
    <TextView android:id="@+id/text2"     
    android:textColor="#ffffff"     
    android:layout_height="30px"     
    android:gravity="center_vertical|left"     
    android:textSize="12px"     
    android:paddingLeft="6px"     
    android:layout_width="fill_parent">     
    </TextView>     
    </LinearLayout>     
    </LinearLayout>     
<?xml version="1.0" encoding="UTF-8"?>   
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    android:layout_width="fill_parent"   
    android:layout_height="wrap_content"   
    android:orientation="vertical"   
    android:id="@+id/widget"   
    android:background="@drawable/title_a">   
    <LinearLayout android:layout_width="fill_parent"   
    android:orientation="horizontal"   
    android:layout_height="wrap_content"   
    android:background="@drawable/title">   
    <TextView android:id="@+id/username_display"   
    android:textStyle="bold"   
    android:layout_width="wrap_content"   
    android:layout_height="fill_parent"   
    android:textColor="#ffffff"   
    android:textSize="15px"   
    android:gravity="left|center_vertical"   
    android:paddingLeft="6px"/>   
    </LinearLayout>   
    <LinearLayout android:orientation="vertical"   
    android:layout_width="fill_parent"   
    android:layout_height="fill_parent">   
       
    <TextView android:id="@+id/text1"   
    android:layout_width="fill_parent"   
    android:textColor="#ffffff"   
    android:textSize="12px"   
    android:gravity="center_vertical|left"   
    android:paddingLeft="6px"   
    android:layout_height="30px">   
    </TextView>   
       
    <TextView android:id="@+id/text2"   
    android:textColor="#ffffff"   
    android:layout_height="30px"   
    android:gravity="center_vertical|left"   
    android:textSize="12px"   
    android:paddingLeft="6px"   
    android:layout_width="fill_parent">   
    </TextView>   
    </LinearLayout>   
    </LinearLayout>  
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
  • 64.
  • 65.
  • 66.
  • 67.
  • 68.
  • 69.
  • 70.
  • 71.
  • 72.
  • 73.
  • 74.
  • 75.
  • 76.
  • 77.
  • 78.
  • 79.
  • 80.
  • 81.
  • 82.
  • 83.
  • 84.
  • 85.
  • 86.

该Widget中包括三个Textview,两个用来显示叽歪的信息,一个用来显示用户名,上述代码比较简单,故不做解释。

(5)由于需要一个Acvivity对象用来输入账户信息,所以在layout目录下新建一个login.xml,作为Activity的配置文件:

<?xml version="1.0" encoding="utf-8"?>     
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"     
    android:orientation="vertical"     
    android:layout_width="fill_parent"     
    android:layout_height="fill_parent"     
    >     
    <TextView android:layout_width="fill_parent"     
    android:layout_height="wrap_content"     
    android:text="@string/hello"     
    android:textColor="#ff8c00"     
    android:capitalize="characters"     
    android:textStyle="bold"/>     
         
    <LinearLayout android:orientation="horizontal"     
    android:layout_width="fill_parent"     
    android:layout_height="wrap_content"     
    android:gravity="center_horizontal">     
         
    <TextView android:layout_width="wrap_content"     
    android:layout_height="wrap_content"     
    android:text="@string/user"     
    android:textColor="#ff8cff"     
    android:capitalize="characters"/>     
         
    <EditText android:id="@+id/username"     
    android:layout_width="200px"     
    android:layout_height="wrap_content"/>     
         
    </LinearLayout>     
         
    <LinearLayout android:orientation="horizontal"     
    android:layout_width="fill_parent"     
    android:layout_height="wrap_content"     
    android:gravity="center_horizontal">     
         
    <TextView android:layout_width="wrap_content"     
    android:layout_height="wrap_content"     
    android:text="@string/code"     
    android:textColor="#ff8cff"     
    android:capitalize="characters"/>     
         
    <EditText android:id="@+id/password"     
    android:layout_width="200px"     
    android:layout_height="wrap_content"     
    android:password="true"/>     
    </LinearLayout>     
         
    <LinearLayout android:orientation="horizontal"     
    android:layout_width="fill_parent"     
    android:layout_height="wrap_content"     
    android:gravity="center_horizontal">     
         
    <Button     
    android:id="@+id/submit"     
    android:layout_width="wrap_content"     
    android:layout_height="wrap_content"     
    android:text="Submit"     
    />     
    </LinearLayout>     
    </LinearLayout>    
<?xml version="1.0" encoding="utf-8"?>   
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"   
    android:orientation="vertical"   
    android:layout_width="fill_parent"   
    android:layout_height="fill_parent"   
    >   
    <TextView android:layout_width="fill_parent"   
    android:layout_height="wrap_content"   
    android:text="@string/hello"   
    android:textColor="#ff8c00"   
    android:capitalize="characters"   
    android:textStyle="bold"/>   
       
    <LinearLayout android:orientation="horizontal"   
    android:layout_width="fill_parent"   
    android:layout_height="wrap_content"   
    android:gravity="center_horizontal">   
       
    <TextView android:layout_width="wrap_content"   
    android:layout_height="wrap_content"   
    android:text="@string/user"   
    android:textColor="#ff8cff"   
    android:capitalize="characters"/>   
       
    <EditText android:id="@+id/username"   
    android:layout_width="200px"   
    android:layout_height="wrap_content"/>   
       
    </LinearLayout>   
       
    <LinearLayout android:orientation="horizontal"   
    android:layout_width="fill_parent"   
    android:layout_height="wrap_content"   
    android:gravity="center_horizontal">   
       
    <TextView android:layout_width="wrap_content"   
    android:layout_height="wrap_content"   
    android:text="@string/code"   
    android:textColor="#ff8cff"   
    android:capitalize="characters"/>   
       
    <EditText android:id="@+id/password"   
    android:layout_width="200px"   
    android:layout_height="wrap_content"   
    android:password="true"/>   
    </LinearLayout>   
       
    <LinearLayout android:orientation="horizontal"   
    android:layout_width="fill_parent"   
    android:layout_height="wrap_content"   
    android:gravity="center_horizontal">   
       
    <Button   
    android:id="@+id/submit"   
    android:layout_width="wrap_content"   
    android:layout_height="wrap_content"   
    android:text="Submit"   
    />   
    </LinearLayout>   
    </LinearLayout> 
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.
  • 18.
  • 19.
  • 20.
  • 21.
  • 22.
  • 23.
  • 24.
  • 25.
  • 26.
  • 27.
  • 28.
  • 29.
  • 30.
  • 31.
  • 32.
  • 33.
  • 34.
  • 35.
  • 36.
  • 37.
  • 38.
  • 39.
  • 40.
  • 41.
  • 42.
  • 43.
  • 44.
  • 45.
  • 46.
  • 47.
  • 48.
  • 49.
  • 50.
  • 51.
  • 52.
  • 53.
  • 54.
  • 55.
  • 56.
  • 57.
  • 58.
  • 59.
  • 60.
  • 61.
  • 62.
  • 63.
  • 64.
  • 65.
  • 66.
  • 67.
  • 68.
  • 69.
  • 70.
  • 71.
  • 72.
  • 73.
  • 74.
  • 75.
  • 76.
  • 77.
  • 78.
  • 79.
  • 80.
  • 81.
  • 82.
  • 83.
  • 84.
  • 85.
  • 86.
  • 87.
  • 88.
  • 89.
  • 90.
  • 91.
  • 92.
  • 93.
  • 94.
  • 95.
  • 96.
  • 97.
  • 98.
  • 99.
  • 100.
  • 101.
  • 102.
  • 103.
  • 104.
  • 105.
  • 106.
  • 107.
  • 108.
  • 109.
  • 110.
  • 111.
  • 112.
  • 113.
  • 114.
  • 115.
  • 116.
  • 117.
  • 118.
  • 119.
  • 120.

有两个EditText用来输入用户名和密码,另外还有一个Button对象。

小结:Android Widget开发详解是本文要介绍的内容,主要是来了解Android Widget内容的学习能对你有所帮助!

责任编辑:zhaolei 来源: CSDN博客
相关推荐

2010-07-13 09:02:19

Widget开发

2011-09-08 13:11:07

Android Wid实例

2011-09-07 13:18:40

Android Wid

2011-09-07 10:34:48

Android Wid

2011-02-28 13:04:27

RelativeLayAndroid Wid

2011-09-09 10:00:20

Android Wid开发

2010-07-23 08:54:02

2011-09-07 17:54:40

Android Wid开发

2011-09-07 14:39:47

Android Wid设计

2011-09-07 13:00:36

2011-09-07 11:15:25

2011-09-08 10:04:07

Windows MobWidget

2011-05-03 15:13:23

BlackBerryWidget

2011-09-07 13:06:04

Android Wid

2011-09-07 14:20:42

Android Wid组件

2010-05-13 10:45:38

2010-07-13 09:08:27

Widget开发

2011-09-13 15:35:40

Widget

2011-09-07 16:28:46

QT WidgetQWidget

2011-09-09 19:05:28

Widget
点赞
收藏

51CTO技术栈公众号