- 提供一组基础的操作用于跨进程更新界面。
- 使用场景:通知栏、桌面小部件
5.1 RemoteViews 的应用
- 通知栏:NotificationManager
- 桌面小部件:AppWidgetProvider,本质是一个广播,SystemServer
5.1.1 RemoteView 在通知栏上的应用
RemoteViews remoteViews = new RemoteView(getPackageName(),R.layout.layout_demo);
remoteViews.setTextViewText(R.id.tv,"test");
remoteViews.setImageViewResource(R.id.iv,R.drawable.ic_demo);
remoteViews.setOnClickPendingIntene(id,PendingIntent);
5.1.2 RemoteView 在桌面小部件上的应用
- AppWidgetProvider 本质上是一个广播,继承BroadcastReceiver
- 步骤
1.定义小部件界面
2.定义小部件配置信息(xml目录下)
3.定义小部件的实现类(继承 AppWidgetProvider)
4.在配置文件中声明小部件
5.1.3 PendingIntent 概述
- PendingIntent:将来某个不确定的时刻发生
- Intent:立刻发生
- PendingIntent 匹配规则:内部 Intent(ComponentName 和 intent-filter) 相同,并且 requestCode相同。
标志 |
简介 |
FLAG_ONE_SHOT |
只能被使用一次,自动cancel |
FLAG_NO_CREATE |
不会主动创建,没有意义,不介绍 |
FLAG_CANCEL_CURRENT |
已经存在,被cancel,创建一个新 PendingIntent,被cancel消息点击无法打开 |
FLAG_UPDATE_CURRENT |
已经存在,会被更新 |
5.2 RemoteView 内部机制
- 通知栏、桌面小部件
- Action 对象的 apply 方法真正操作 View的地方
- RemoteViews 通过 安排apply 和 reApply 来加载或更新界面,前者会加载布局并更新界面,后者只会更新界面。
5.3 RemoteViews 的意义
- RemoteViews 仅支持常见的 View ,自定义 View 不支持。
- A 和 B 属于不同 应用,通过资源名称来加载布局文件。(getResource().getIndentifier(“资源名称”,“layout”,getPackageName()))