android widget

一、主要框架

  • 1、AppWidgetProvider :继承自 BroadcastRecevier , 在AppWidget 应用 update、enable、disable 和 delete 时接收通知。其中,onUpdate、onReceive 是最常用到的方法,它们接收更新通知。
  • 2、 AppWidgetProvderInfo:描述 AppWidget 的大小、更新频率和初始界面等信息,以XML 文件形式存在于应用的 res/xml/目录下。
  • 3、AppWidgetManger :负责管理 AppWidget ,向 AppwidgetProvider 发送通知。
  • 4、RemoteViews :一个可以在其他应用进程中运行的类,向 AppWidgetProvider 发送通知。

    二、开发步骤

    1.在res\xml中建立widget内容提供者文件,取名为widget_provider.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
        android:minWidth="60dp"
        android:minHeight="30dp"
        android:updatePeriodMillis="86400000"     
        android:initialLayout="@layout/main">
    </appwidget-provider>
    

    android:initialLayout="@layout/main" 此句为指定桌面组件的布局文件。

    android:updatePeriodMillis="86400000"指定刷新时间间隔(单位:ms),每隔android:updatePeriodMillis就调用onUpdate方法。另,如果android:updatePeriodMillis为0,则表示不刷新。

    android:minWidth最小宽度
    android:minHeight最小高度

    可以根据所占单元格数计算android:minWidth和android:minHeight。

    计算公式(宽高皆适用):(单元个数*74)-2。由于像素计算会造成一定的偏差,所以最后值减2。另,屏幕最大单元格数位4*4。

    2.写一个类继承自AppWidgetProvider

    public class widgetProvider extends AppWidgetProvider


    并重写两个方法

    @Override
        public void onUpdate(Context context, AppWidgetManager appWidgetManager,
                int[] appWidgetIds) {}
    
    @Override
        public void onReceive(Context context, Intent intent) {}

    onUpdate 为组件在桌面上生成时调用,并更新组件UI,onReceiver 为接收广播时调用更新UI,一般这两个方法是比较常用的。

    3.后台注册Receiver

    <receiver android:name=".widgetProvider">
                <meta-data android:name="android.appwidget.provider"
                    android:resource="@xml/appwidget_provider"></meta-data>
                <intent-filter>
                    <action android:name="com.terry.action.widget.click"></action>
                    <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
                     
                </intent-filter>
            </receiver>
    
    

    上面代码中比较重要的是这一句 <meta-data android:name="android.appwidget.provider"  android:resource="@xml/appwidget_provider"></meta-data>  大意为指定桌面应用程序的AppWidgetProvderInfo  文件,使其可作其管理文件。

    4.使app widget组件支持点击事件

    public static void updateAppWidget(Context context,
                AppWidgetManager appWidgeManger, int appWidgetId) {
            rv = new RemoteViews(context.getPackageName(), R.layout.main);
            Intent intentClick = new Intent(CLICK_NAME_ACTION);
            PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0,
                    intentClick, 0);
            rv.setOnClickPendingIntent(R.id.TextView01, pendingIntent);
            appWidgeManger.updateAppWidget(appWidgetId, rv);
        }
    

    此方法为创建组件时 onUpdate 调用的更新UI的方法,代码中使用RemoteView 找到组件的布局文件,同时为其设置广播接收器CLICK_NAME_ACTION并且通过RemoteView 的setOnClickPendingIntent 方法找到我想触发事件的TextView 为其设置广播。接着在onReceiver 中通过判断传进来的广播来触发动作。

    @Override
        public void onReceive(Context context, Intent intent) {
            // TODO Auto-generated method stub
            super.onReceive(context, intent);
    
            if (rv == null) {
                rv = new RemoteViews(context.getPackageName(), R.layout.main);
            }
            if (intent.getAction().equals(CLICK_NAME_ACTION)) {
                if (uitil.isChange) {
                    rv.setTextViewText(R.id.TextView01, context.getResources()
                            .getString(R.string.load));
    
                } else {
                    rv.setTextViewText(R.id.TextView01, context.getResources()
                            .getString(R.string.change));
    
                }
                Toast.makeText(context, Boolean.toString(uitil.isChange),
                        Toast.LENGTH_LONG).show();
                uitil.isChange = !uitil.isChange;
    
            }
            AppWidgetManager appWidgetManger = AppWidgetManager
                    .getInstance(context);
            int[] appIds = appWidgetManger.getAppWidgetIds(new ComponentName(
                    context, widgetProvider.class));
            appWidgetManger.updateAppWidget(appIds, rv);
        }
    




     

### 创建和使用 Android Widget #### 定义小部件配置信息 为了定义一个小部件,需在 `res/xml` 文件夹下创建一个 XML 文件来指定其基本属性。此文件通常命名为 `appwidget.xml` 或类似的名称。通过设置不同的属性,可以控制小部件的行为及其外观尺寸。 ```xml <appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android" android:minWidth="100dp" android:minHeight="50dp" android:updatePeriodMillis="0" android:initialLayout="@layout/widget_layout"> </appwidget-provider> ``` 上述代码片段展示了如何设定最小度 (`minWidth`) 和度 (`minHeight`) 属性以及初始布局资源 ID (`initialLayout`) [^2]。 #### 实现自定义视图的小部件布局 对于希望展示给用户的界面部分,则需要设计相应的布局文件。这可以通过编辑位于 `res/layout/` 下的一个名为 `widget_layout.xml` 的文件实现: ```xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:padding="8dp" android:layout_width="match_parent" android:layout_height="wrap_content"> <!-- 添加具体的UI组件 --> </LinearLayout> ``` 注意,在实际应用中可以根据需求调整根元素类型并添加更多子级 UI 组件以构建复杂多样的视觉效果 [^4]。 #### 注册广播接收器处理更新事件 为了让系统知道何时刷新或初始化小部件的内容,还需要编写一段 Java/Kotlin 代码用于监听特定类型的广播消息——特别是那些携带了 `ACTION_APPWIDGET_UPDATE` 动作的消息。这部分逻辑一般放在继承自 `AppWidgetProvider` 类的新类里完成,并且要在清单文件(`AndroidManifest.xml`) 中声明该服务作为广播接收器的一部分 [^3]。 ```java public class MyWidget extends AppWidgetProvider { @Override public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) { // 更新每个实例的逻辑... super.onUpdate(context, appWidgetManager, appWidgetIds); } } ``` 最后一步是在应用程序的 `AndroidManifest.xml` 清单文件内注册这个新的广播接收器和服务关联关系: ```xml <receiver android:name=".MyWidget"> <intent-filter> <action android:name="android.appwidget.action.APPWIDGET_UPDATE"/> </intent-filter> <meta-data android:name="android.appwidget.provider" android:resource="@xml/appwidget_info"/> </receiver> ``` 这样就完成了整个过程,使得开发者能够成功地向用户提供功能丰富的桌面小工具 [^1]。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值