创建 widget 窗口小组件

随着android的手机屏幕越来越大,为了丰富屏幕内容 app widget(窗口小组件)被越来越多的应用所使用。app widget 有什么好处呢?它可以在不启动应用程序的情况下,让用户在屏幕上有一块交互窗口和程序入口点。

这是我手机自带的天气预报app widget效果。

 

为了创建一个应用程序的widget我们需要创建三个组件:

(1)给widget创建一个布局资源。

res/layout/nview.xml

复制代码
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="打开网页" />

    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="打开照相机" />

    <Button
        android:id="@+id/button3"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="打开电话本" />

</LinearLayout>
View Code
复制代码

Widget的布局不是支持所有Android组件的。目前仅支持一下组件。

FrameLayout 
LinearLayout 
RelativeLayout 

AnalogClock 
Button 
Chronmeter 
ImageButton 
ImageView 
ProgressBar 
TextView 

如果使用了weidget不支持的组件。那么在Widget创建时会导致android.view.InflateExceptionn异常 

 

 

(2)创建widget描述文件。该文件是xml类型。位于res/xml中

res/xml/my_widget.xml

复制代码
<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
    android:initialLayout="@layout/nview"
    android:minHeight="40dp"
    android:minWidth="200dp"
    android:previewImage="@drawable/ic_launcher"
    android:resizeMode="horizontal|vertical"
    android:configure="com.example.testdemo.MainActivity"
    android:updatePeriodMillis="360000" >

</appwidget-provider>
View Code
复制代码

appwidget-provider标签能够描述widget元数据。该元数据使用以下属性来描述weiget

initialLayout: widget的布局资源。

minWidth/minHeight: widget的最小宽度和最小高度。

resizeMode: (这个属性是在Android 3.1中引入的)通过给resizeMode设置horizontal和vertical的组合,允许在你指定的方向上调整widget的大小,设置为none会禁止调整大小。

lable: 小组件标题,在小组件列表中能看到。

updatePeriodMillis: widget更新最小周期,单位毫秒。Android将会以该设定的时间唤醒设备,来更新主屏幕上的widget,这个时间周期不能小于30分钟。最好每天更新一到两次

icon: 你的widget 在小组件管理器中的图标。你可以指定icon为你的weiget的缩略图。方便用户了解你的widget样子。

configure:当widget添加到屏幕中时,可以启动一个Activity,该Acitvity可以对widget进行设置,该属性必须使用Activity的完全限定名,如上代码中的。

perviewImage: (Android3.0中引入的)设置widget在小组件管理器中的预览效果。而不是显示其图标icon。其实这个和icon差不多。最好还是用这个。

 

(3)创建一个继承于AppWidgetProvider的Intent接受类,AppWidgetProvider封装了对Intent的处理,并提供了更新,删除,启用,禁用等事件的处理程序,在该类中我们可以从服务器端获得数据并进行处理并在Widget中显示等。

复制代码
package com.example.testdemo;

import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.Context;
import android.content.Intent;

public class MyAppWidget extends AppWidgetProvider {

    @Override
    public void onDeleted(Context context, int[] appWidgetIds) {
        // Widget组件被删除时触发
        super.onDeleted(context, appWidgetIds);
    }

    @Override
    public void onDisabled(Context context) {
        // 最后一个Widget组件关闭时触发
        super.onDisabled(context);
    }

    @Override
    public void onEnabled(Context context) {
        // 第一个Widget组件启动时触发 
        super.onEnabled(context);
    }

    @Override
    public void onReceive(Context context, Intent intent) {
        // 没接收一次广播消息就调用一次,使用频繁,不管什么操作都最先触发该函数 
        super.onReceive(context, intent);
    }

    @Override
    public void onUpdate(Context context, AppWidgetManager appWidgetManager,
            int[] appWidgetIds) {
        // 当更新widget时调用
        super.onUpdate(context, appWidgetManager, appWidgetIds);
    }
}
View Code
复制代码

 

 

 

(4)向AndroidManifest.xml中注册

 

复制代码
  <receiver android:name=".MyAppWidget" >
            <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
            </intent-filter>
            <meta-data
                android:name="android.appwidget.provider"
                android:resource="@xml/my_widget" >
            </meta-data>
        </receiver>
View Code
复制代码

注意:使用的是Receiver标签,为了把一个broadcaset Receiver 指定为一个 app widget。需要添加以下两个标签。

1.一个用于"android.appwidget.action.APPWDIGET_UPDATE" 动作的intent filter。

2.一个对描述文件widget的xml引用。这个文件描述了widget的设置。

 

更多属性参加Android api

posted @   仰望 星空  阅读(871)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示