• 点击Notification正确回调到之前已经放置在后台的Task中的对应Activity,而不是创建它的一个新实例


     NotificationManager notificationManager = (NotificationManager)getSystemService(NOTIFICATION_SERVICE);
     Notification notification = new Notification(R.drawable.logo_icon_16,"移动营销", System.currentTimeMillis());
     Intent intent = new Intent(Intent.ACTION_MAIN); 
     intent.addCategory(Intent.CATEGORY_LAUNCHER); 
     intent.setClass(this, BeforeLogoActivity.class); 
     intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK|Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);
     notification.flags = Notification.FLAG_ONGOING_EVENT; // 设置常驻 Flag
     PendingIntent contextIntent = PendingIntent.getActivity(this, 0, intent, 0);
     notification.setLatestEventInfo(getApplicationContext(),"移动营销", "", contextIntent);
     notificationManager.notify(R.drawable.logo_icon_16, notification);
    

      除了 setClass 可以换成使用 setClassName 绑定,FLAG_ACTIVITY_RESET_TASK_IF_NEEDED可以不设,其他的选项都缺一不可。设置ACTION_MAIN与CATEGORY_LAUNCHER是把该Intent发给了系统对应创建程序的模块,然后系统该模块根据设定的包与类信息还有flags进行处理。当然所有的Intent工作原理都是这样,只是对 ACTION_MAIN - CATEGORY_LAUNCHAR 的处理较为特殊,使得总是显示Task栈顶的Activity而不是setClass设定的Activity类。

    转自:http://blog.csdn.net/zz_mm/article/details/8021428

  • 相关阅读:
    16.检查是否为BST
    15.输出单层结点
    14.高度最小的BST
    *13.有向路径检查
    12.二叉树平衡检查
    11.双栈排序
    10.回文链表
    9.链式A+B
    8.链表分割
    7.访问单个节点的删除
  • 原文地址:https://www.cnblogs.com/l2rf/p/3009211.html
Copyright © 2020-2023  润新知