理解 RemoteViews

RemoteViews 在 Android 中的应用场景有两种:通知栏和桌面小部件上的应用。

5.1 RemoteViews 的应用

5.1.1 RemoteViews 的通知栏上的应用

        Notification notification = new Notification();
        Intent intent = new Intent(this, SecondActivity.class);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, intent, PendingIntent.FLAG_UPDATE_CURRENT);

        RemoteViews remoteViews = new RemoteViews(getPackageName(), R.layout.item_1);
        remoteViews.setTextViewText(R.id.my_text,"你个大便");
        remoteViews.setOnClickPendingIntent(R.id.item_1, pendingIntent);
        notification.contentView = remoteViews;
        notification.contentIntent = pendingIntent;
        NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        manager.notify(2,notification);
理解 RemoteViews_第1张图片
GIF.gif

5.1.2 RemoteViews 在桌面小部件上的应用

5.1.3 PendingIntent

PendingIntent 支持三种待定的意图:

  • static PendingIntent getActivities (启动 Activity):
    public static PendingIntent getActivities (Context context, int requestCode,
            Intent intent, int flags) {

获得一个 PendingIntent,待特定意图发生时,相当于 Context.startActivity(Intent)

  • static PendingIntent getService(启动 getService):
    public static PendingIntent getService(Context context, int requestCode,
            Intent intent, int flags) {

获得一个 PendingIntent,待特定意图发生时,相当于 Context.startService(Intent)

  • static PendingIntent getBroadcast(发生广播):
    public static PendingIntent getBroadcast(Context context, int requestCode,
            Intent intent, int flags) {

获得一个 PendingIntent,待特定意图发生时,相当于 Context.sendBroadcast(Intent)

  • context:上下文
  • requestCode:Pending 放送方的请求码,设为 0 即可;
  • intent:意图
  • flags:
  • FLAG_ONE_SHOT
    当前描述的 PendingIntent 只能被使用一次,然后就是自动 cancel。
  • FLAG_NO_CREATE
    当前描述的 PendingIntent 不会主动创建,没有太多的实用意义。
  • FLAG_CANCEL_CURRENT
    当前的 PendingIntent 如果已经存在,那么都会被 cancel,然后系统会创建一个新的。
  • FLAG_UPDATE_CURRENT
    当前描述的 PendingIntent 如果已经存在,那么他们会被更新,即 Intent 中的 Extras 会更新。

pendingIntent 的匹配规则为:如果两个 PendingIntent 他们内部的 Intent 相同并且 requestCode 也相同,那么它们就相同。

Intent 的匹配规则为:两个 Intent 的 ComponentName 和 intent-filter 都相同,那么它们就相同。

5.2 RemoteViews 的内部机制

RemotesViews 支持的 View 类型有:

  • Layout

FrameLayout、LinearLayout、RelativeLayout、GridLayout

  • View

AnalogClock、Button、Chronometer、ImageButton、ImageView、ProgressBar、TextView、
ViewFlipper、ListView、GridView、StackView、AdapterViewFlipper、ViewStub。

RemotesView 不支持它们的子类以及其他 View 类型。

通知栏和桌面小部件分别由 NotificationManager 和 AppWidgetManager 管理,他们通过 Binder 分别和 SystemServer 进程中的 NotificationManagerService 和 AppWidgetService 进行通信。由此可见,通知栏和桌面小部件中的布局文件实际上是在 NotificationManagerService 以及 AppWidgetService 中被加载的,而他们运行在系统的 SystemServer 中,这就和我们形成了跨进程通信的场景。

5.3 RemoteViews

理解 RemoteViews_第2张图片
GIF.gif

你可能感兴趣的:(理解 RemoteViews)