Widget简介

Widget简介

可以使用AppWidgetManager更新Widget中的数据,但这样最短也要半个小时才能更新一次,一般不用他更新,而是自己定义一个服务去更新Widget中的数据。

Widget的创建步骤

  1. 写一个类继承AppWidgetProvider,这个是一个广播接收者,所以要在清单文件中进行配置
public class MyWidget extends AppWidgetProvider {
	@Override
	public void onEnabled(Context context) {
		//开启服务定期的更新界面.
		Intent intent = new Intent(context,UpdateWidgetService.class);
		context.startService(intent);
		super.onEnabled(context);
	}
	
	@Override
	public void onDisabled(Context context) {
		//关闭掉服务
		Intent intent = new Intent(context,UpdateWidgetService.class);
		context.stopService(intent);
		super.onDisabled(context);
	}
				
	@Override
	public void onUpdate(Context context, AppWidgetManager appWidgetManager,
			int[] appWidgetIds) {      
		//Widget布局中定义的更新时间到了。检查下 服务是否还活着.
		if(!ServiceStatusUtil.isServiceRunning(context, "com.itheima.mobilesafe.service.UpdateWidgetService")){
			Intent intent = new Intent(context,UpdateWidgetService.class);
			context.startService(intent);
		}
		super.onUpdate(context, appWidgetManager, appWidgetIds);
	}
}
  1. 在清单文件中进行配置,内容如下:
<receiver android:name=".receiver.MyWidget" >
	<intent-filter>
		<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
	</intent-filter>
	<meta-data
		android:name="android.appwidget.provider"
		android:resource="@xml/example_appwidget_info" />//这里使用到了一个xml文件,所以要创建这个文件
</receiver>
  1. 在res下面新建一个名为xml的文件件,然后新建example_appwidget_info.xml内容如下
<?xml version="1.0" encoding="utf-8"?>
<appwidget-provider xmlns:android="http://schemas.android.com/apk/res/android"
	android:minWidth="294dp"
	android:minHeight="72dp"
	android:updatePeriodMillis="86400000" //指定更新的间隔时间,最小为半个小时,一般不用它更新,都是自己更新
	android:previewImage="@drawable/preview"//指定小控件的图标,如果不要这个选项就是程序的图标
	android:initialLayout="@layout/example_appwidget"//设置这个小控件的布局文件
	android:configure="com.example.android.ExampleAppWidgetConfigure" //有些复杂的Widget在点击的时候会去开启一个Activity,
	// 这时候就是通过这个参数来配置要开启的Activity,用不着就删除这一行	android:resizeMode="horizontal|vertical">
	//这个是Android3.0的一个新特性,是可以让widget改变大小,在2.3时候创建出来的Widget多大就是多大,不能改变,可以把这个去掉
</appwidget-provider>
  1. 更新Widget数据的服务
public class UpdateWidgetService extends Service {
	private Timer timer;
	private TimerTask task;
	@Override
	public IBinder onBind(Intent intent) {
		return null;
	}
	@Override
	public void onCreate() {
		super.onCreate();
		// 开启定期的任务更新widget.
		timer = new Timer();
		task = new TimerTask() {
			@Override
			public void run() {
				AppWidgetManager awm = AppWidgetManager
						.getInstance(getApplicationContext());
				ComponentName component = new ComponentName(
						getApplicationContext(), MyWidget.class);
				RemoteViews views = new RemoteViews(getPackageName(),
						R.layout.process_widget);
				views.setTextViewText(
						R.id.process_count,
						"正在运行:"
								+ ProcessStatusUtils.getProcessCount(getApplicationContext())
								+ "个");
				views.setTextViewText(
						R.id.process_memory,
						"可用内存:"
								+ Formatter
										.formatFileSize(
												getApplicationContext(), ProcessStatusUtils.getAvailRAM(getApplicationContext())));
				Intent intent = new Intent();
				intent.setAction("com.itheima.killall");
				//设置一个自定义的广播事件 动作  com.itheima.killall
				PendingIntent pendingIntent = PendingIntent.getBroadcast(getApplicationContext(), 0, intent, 0);
				views.setOnClickPendingIntent(R.id.btn_clear, pendingIntent);
				awm.updateAppWidget(component, views);
			}
		};
		timer.schedule(task, 1000, 2000);
	}
	@Override
	public void onDestroy() {
		timer.cancel();
		task.cancel();
		timer = null;
		task = null;
		super.onDestroy();
	}
}

Widget的声明周期

`Widget`就是一个特殊的广播接收者 1. 当界面上第一个`widget`被创建的时候 01-14 02:17:14.348: INFO/System.out(1853): onEnabled 当`widget`第一次被创建的时候调用. 非常适合做应用程序的初始化. 01-14 02:17:14.348: INFO/System.out(1853): onReceive 01-14 02:17:14.357: INFO/System.out(1853): onUpdate 当有新的`widget`被创建的时候 更新界面的操作. 当时间片到的时候`onupdate()`调用. 01-14 02:17:14.357: INFO/System.out(1853): onReceive 2. 当界面上第二个`widget`被创建的时候 01-14 02:18:10.148: INFO/System.out(1853): onUpdate 01-14 02:18:10.148: INFO/System.out(1853): onReceive 3. 再创建新的`widget` 01-14 02:18:10.148: INFO/System.out(1853): onUpdate 01-14 02:18:10.148: INFO/System.out(1853): onReceive 4. 从界面上移除一个`widget` 01-14 02:19:11.709: INFO/System.out(1853): onDeleted 01-14 02:19:11.709: INFO/System.out(1853): onReceive 5. 最后一个`widget`被移除 01-14 02:19:37.509: INFO/System.out(1853): onDeleted 01-14 02:19:37.509: INFO/System.out(1853): onReceive 01-14 02:19:37.509: INFO/System.out(1853): onDisabled 当`widget`从界面上全部移除的时候调用的方法. 非常适合删除临时文件停止后台服务. 01-14 02:19:37.509: INFO/System.out(1853): onReceive 6. `widget`就是一个特殊的广播接受者 当有新的事件产生的是 肯定会调用 `onReceive()`;

注意: 在不同的手机上 widget的生命周期调用方法 可能有细微的不同.

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏开发技术

从源码来理解slf4j的绑定,以及logback对配置文件的加载

  项目中的日志系统使用的是slf4j + logback。slf4j作为一个简单日志门面,为各种loging APIs(像java.util.logging,...

1874
来自专栏Android 研究

Android系统启动——4 zyogte进程 (C篇)

我们大家都是知道"一鼎三足"和"三角形的稳定性",那么支撑Android系统的三个"足"是什么?即init进程、SystemServer进程和Zygote进程。...

2381
来自专栏大大的微笑

RMI

RMI定义:     RMI即远程方法调用(Remote Method Invocation)。能够让在某个java虚拟机上的对象像调用本地对象一样调用另一个j...

2645
来自专栏我是攻城师

Java并发之高级自旋锁CLH锁和MCS锁

自旋锁(spin lock)是一个典型的对临界资源的互斥手段,自旋锁是基于CAS原语的,所以它是轻量级的同步操作,它的名称来源于它的特性。自旋锁是指当一个线程尝...

2123
来自专栏青蛙要fly的专栏

Android技能树 — 多进程相关小结

这次是讲Android存储路径及IO的基本操作。因为我们在开发的时候会经常这种方便的需求。这篇文章的内容我写的可能很少,都没有细写。别吐槽。o( ̄︶ ̄)o

691
来自专栏Ryan Miao

在dropwizard中使用feign,使用hystrix

前言 用惯了spring全家桶之后,试试dropwizard的Hello World也别有一帆风味。为了增强对外访问API的能力,需要引入open feign...

40112
来自专栏Ryan Miao

使用dropwizard(4)-加入测试-jacoco代码覆盖率

前言 dropwizard提供了一个简单的测试框架。这里简单集成并加入jacoco测试。 Demo source https://github.com/Rya...

3968
来自专栏乐沙弥的世界

使用 runcluvfy 校验Oracle RAC安装环境

--*****************************************

1032
来自专栏Eugene's Blog

SQL手工注入语法分类目录文章标签友情链接联系我们

1265
来自专栏java、Spring、技术分享

Hystrix源码解析

  在分布式系统中,难免有对外部接口的依赖,而外部接口有可能出现响应缓慢,大量请求超时,大量访问出现异常等情况。出现上面所说的情况有可能是由很多原因导制的,可能...

3583

扫码关注云+社区