随笔 - 1357  文章 - 0  评论 - 1104  阅读 - 1941万

Android之桌面组件App Widget案例

模拟一个案例:把AppWidget添加到桌面后,点击AppWidget后AppWidget文本会轮回改变

main.xml布局文件

复制代码
<?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:id="@+id/tv"
android:layout_width
="fill_parent"
android:layout_height
="wrap_content"
android:text
="程序入口"
android:textSize
="50dip"/>
</LinearLayout>
复制代码

res/xml/my_appwidget.xml布局文件

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

清单文件

复制代码
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.ljq.activity" android:versionCode="1"
android:versionName
="1.0">
<application android:icon="@drawable/icon"
android:label
="@string/app_name">
<receiver android:name=".TestActivity">
<meta-data android:name="android.appwidget.provider"
android:resource
="@xml/my_appwidget">
</meta-data>
<intent-filter>
<action android:name="COM.LJQ.ACTION.WIDGET.CLICK"></action>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
</receiver>
</application>
<uses-sdk android:minSdkVersion="7" />

</manifest>
复制代码

变量类UtilTool:用来控件文本改变

package com.ljq.activity;


public class UtilTool {
public static boolean isChange=true;
}

TestActivity类,继承自AppWidgetProvider

复制代码
package com.ljq.activity;

import android.app.PendingIntent;
import android.appwidget.AppWidgetManager;
import android.appwidget.AppWidgetProvider;
import android.content.ComponentName;
import android.content.Context;
import android.content.Intent;
import android.widget.RemoteViews;

public class TestActivity extends AppWidgetProvider {
// 自定义一个Action名
private static final String ACTION_CLICK_NAME = "COM.LJQ.ACTION.WIDGET.CLICK";
private RemoteViews rv;

@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
System.out.println(
"onUpdate");
//获取R.layout.main布局,通过类RemoteViews对布局R.layout.main里的控件进行操作
/*rv = new RemoteViews(context.getPackageName(), R.layout.main);
Intent intentClick = new Intent(ACTION_CLICK_NAME);
PendingIntent pendingIntent = PendingIntent.getBroadcast(context, 0, intentClick, 0);
rv.setOnClickPendingIntent(R.id.tv, pendingIntent);

ComponentName cmp = new ComponentName(context, TestActivity.class);
AppWidgetManager myAppWidgetManager = AppWidgetManager.getInstance(context);
myAppWidgetManager.updateAppWidget(cmp, rv);
*/
final int N = appWidgetIds.length;
for (int i = 0; i < N; i++) {
int appWidgetId = appWidgetIds[i];
updateAppWidget(context, appWidgetManager, appWidgetId);
}

}

//AppWidget生命周期: 每接收一次,广播执行一次为一个生命周期结束。
//也就是说在重写AppWidgetProvider类里面声明全局变量做状态判断,
//每次状态改变AppWidgetProvider再接收第二次广播时即为你重新初始化也就是说重新实例化了一次AppWidgetProvider。
//今天我因为在里面放了一个boolean值初始化为true,观察调试看到每次进入都为TRUE故你在设置桌面组件时,
//全局变量把它声明在另外一个实体类用来判断是没问题的,切忌放在本类。
@Override
public void onReceive(Context context, Intent intent) {
System.out.println(
"onReceive");
if (rv == null) {
rv
= new RemoteViews(context.getPackageName(), R.layout.main);
}
if (intent.getAction().equals(ACTION_CLICK_NAME)) {
if (UtilTool.isChange) {
rv.setTextViewText(R.id.tv,
"abc");
}
else {
rv.setTextViewText(R.id.tv,
"123");
}
UtilTool.isChange
= !UtilTool.isChange;
AppWidgetManager appWidgetManger
= AppWidgetManager.getInstance(context);
int[] appIds = appWidgetManger.getAppWidgetIds(new ComponentName(context, TestActivity.class));
appWidgetManger.updateAppWidget(appIds, rv);
}
else{
super.onReceive(context, intent);
}

}

private void updateAppWidget(Context context,
AppWidgetManager appWidgeManger,
int appWidgetId) {
rv
= new RemoteViews(context.getPackageName(), R.layout.main);
Intent intentClick
= new Intent();
intentClick.setAction(ACTION_CLICK_NAME);
PendingIntent pendingIntent
= PendingIntent.getBroadcast(context, 0, intentClick, 0);
rv.setOnClickPendingIntent(R.id.tv, pendingIntent);
appWidgeManger.updateAppWidget(appWidgetId, rv);
}

}
复制代码
posted on   Ruthless  阅读(4004)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
· AI 智能体引爆开源社区「GitHub 热点速览」
< 2011年3月 >
27 28 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 1 2
3 4 5 6 7 8 9

点击右上角即可分享
微信分享提示