消息栏通知(Notification)介绍

用过安卓的应该对通知栏消息都很熟悉了,下面是演示通知栏消息的一个Demo,首先来看一下界面,后面是代码,解释就都放在代码里了.java代码package jason.notification;import android.app.Activity;import android.app.Notification;import android.app.Notificat

大家好,又见面了,我是全栈君。

用过安卓的应该对通知栏消息都很熟悉了,下面是演示通知栏消息的一个Demo,首先来看一下界面,后面是代码,解释就都放在代码里了.

消息栏通知(Notification)介绍消息栏通知(Notification)介绍

java代码

package jason.notification;

import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Context;
import android.content.Intent;
import android.os.Bundle;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class MainActivity extends Activity {
	Button button;int id = 0;
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		button = (Button) findViewById(R.id.notify);
		button.setOnClickListener(new OnClickListener() {
			
			@Override
			public void onClick(View arg0) {
				//获得通知管理器
				NotificationManager manager = (NotificationManager)getSystemService(Context.NOTIFICATION_SERVICE);
				//构建一个通知对象(需要传递的参数有三个,分别是图标,标题和 时间)
				Notification notification = new Notification(R.drawable.ic_launcher,"通知",System.currentTimeMillis());
				Intent intent = new Intent(MainActivity.this,MainActivity.class);
				PendingIntent pendingIntent = PendingIntent.getActivity(MainActivity.this,0,intent,0);						                          notification.setLatestEventInfo(getApplicationContext(), "通知标题", "通知显示的内容", pendingIntent);
				notification.flags = Notification.FLAG_AUTO_CANCEL;//点击后自动消失
				notification.defaults = Notification.DEFAULT_SOUND;//声音默认
				manager.notify(id, notification);//发动通知,id由自己指定,每一个Notification对应的唯一标志
				//其实这里的id没有必要设置,只是为了下面要用到它才进行了设置

			}
		});
	}
}


 

对于通知的结构下面有个图很好的进行了标注;

消息栏通知(Notification)介绍

以下是每个部分的说明:

1. 内容标题

2. 大型icon

3. 内容text

4. 内容info

5. 小型icon

6. 发布通知的时间。你能使用setWhen()设置一个明确的值。

 

下面再具体的记录一下其他细节

我们可以为Notification指定它的图标,标题,时间,提醒方式,点击之后的动作。还能做什么呢

 

1、由于每个Notification的ID是唯一的,所以我们可以删除某些通知:

manager.cancel(id, notification);

 

2、同理,通过重复发送相同ID的Notification,我们还可以更新某些通知:

manager.notify(id, new_notification);

 

3由于Notification的包装内容为Intent,我们就可以方便地为通知被点击的触发的事件传值:

现在回到下面的位置来

PendingIntent pendingIntent = PendingIntent.getActivity(MainActivity.this,0,new Intent(MainActivity.this,MainActivity.class),0);

注意最后一个“0”,0表示什么?表示什么都不做,下次你传进来的Intent,如果被发现是同一个Intent,则所有通知都保持为同一个Intent,只是新来的Extra被保留了。

我们应该期望每个Notification都能干点不一样的事情,按上面的方式这样来,每个具备相同Intent的Notification相互之间,其实是毫无区别的。

好,我们来看下除了0以外Android还有什么设置:

 

1、PendingIntent.FLAG_UPDATE_CURRENT

如果该PendingIntent已经存在,则用新传入的Intent的Extra更新当前的数据。

2、PendingIntent.FLAG_ONE_SHOT

send()只能被执行一次,即是说,假如该通知点击后不消失,那么再次点击不会发生任何事。

3、PendingIntent.FLAG_NO_CREATE

如果该PendingIntent不存在,直接返回null而不是创建一个PendingIntent.

4、PendingIntent.FLAG_CANCEL_CURRENT

如果该PendingIntent已经存在,则在生成新的之前取消当前的。

 

嗯,明显都不是我们想要的。

 

其实答案根本不在PendingIntent包装上。

PendingIntent所做的全部事情都只是对同样的Intent进行处理,关键词,在于“同样的”

既然每次你打开的都是同一个Intent,那区分PendingIntent就没有意义了

所以,在Intent定义的时候,你还需要区分Intent

推荐方式:

intent.setData(Uri.parse("custom://"+System.currentTimeMillis()));

这样就实现了Intent的区别化,以后每次传入的Intent都会具备不同的Extra,当然,PendingIntent需要定义为PendingIntent.FLAG_UPDATE_CURRENT

 

到这个地方,其实还剩下一个问题,很快你就会发现

每次点击通知,都正确的弹出你要的Activity,但是之前的打开的Activity依旧存在

方法有二:

1、在Activity的onPause()方法体中增加:

finish();

这样,在打开新的Activity的时候,旧的就进入了暂停态,启动onPause(),然后执行finish(),活动结束

好吧,这是个蠢办法,请不要使用

2、设置Intent:

intent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

是的,这句就够了,这里我得说一下Activity的栈机制:

我们先来看看Intent的结构new Intent(MainActivity.this,MainActivity.class);

第一个参数为产生该意图(Intent)的活动,这个逻辑再清晰不过了,要做的事情得有个发出的主体

第二个参数为该意图的对象,即是这个意图是什么,我们来看看。

呃!??这里没有对象……

是的,我们只有了一个对象的类名,但远远不是某个具体的对象,这是反射么?反射能通过一个类名来找到某个特定的类实例么?

 

事实如下:

Android有一个栈机制,每个产生的活动在过了产生期后,都会进入这个栈,新的活动压着旧的活动,每一次寻找类名的时候,都默认提取的是栈顶的活动。这也是为什么Android能快捷的执行返回操作。

回到原点来,我们为Intent添加:

openintent.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);

之后,这个意图一旦产生,就会自动清除栈顶的活动,即是说,上一个被打开的活动会被终结掉,于是就实现了没有两个相同的活动被同时打开。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/121458.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • pycharm激活码永久破解(JetBrains全家桶)

    (pycharm激活码永久破解)2021最新分享一个能用的的激活码出来,希望能帮到需要激活的朋友。目前这个是能用的,但是用的人多了之后也会失效,会不定时更新的,大家持续关注此网站~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月30日
    289
  • 修改phpstorm的字体样式和大小

    修改phpstorm的字体样式和大小

    2021年10月15日
    54
  • ORACLE分页查询SQL语句(最有效的分页)

    ORACLE分页查询SQL语句(最有效的分页)**一、效率高的写法**1.无ORDERBY排序的写法。(效率最高)(经过测试,此方法成本最低,只嵌套一层,速度最快!即使查询的数据量再大,也几乎不受影响,速度依然!)SELECT*FROM(SELECTROWNUMASrowno,t.*FROMemptWHEREhire_dateBETWEENTO_DATE…

    2022年4月29日
    530
  • C#中IntPtr类型

    1.C#中的IntPtr类型被称之为“平台特定的整数类型”,用于本机资源,例如窗口句柄。2.资源的大小取决于使用的硬件和操作系统,即此类型的实例在32位硬件和操作系统中将是32位,在64位硬件和操作系统中将是64位;但其大小总是足以包含系统的指针(因此也可以包含资源的名称)。3.在调用API函数时,类似含有窗口句柄参数(HANDLE)的原型函数,应显示地声明为IntPtr类型。4.In…

    2022年4月4日
    190
  • 苹果屏蔽更新描述文件_屏蔽iPhone更新的iOS描述文件安装办法「建议收藏」

    屏蔽iOS更新分两种,第一种非越狱设备,只能系统在12.1以下的才能安装屏蔽描述文件safari浏览器输入ibeta.me回车,找到下图的屏蔽OTA更新,直接安装就行了第二种越狱设备,首先添加源https://xsf1re.github.io/repo/安装下图这个插件这个文件可以解除12.1以上设备描述文件失效不允许安装的问题,作者说写着兼容12.4-13.3,其他系统的老铁们自…

    2022年4月11日
    454
  • 前端的模块化_模块化设计

    前端的模块化_模块化设计前言在JavaScript发展初期就是为了实现简单的页面交互逻辑,寥寥数语即可;如今CPU、浏览器性能得到了极大的提升,很多页面逻辑迁移到了客户端(表单验证等),随着web2.0时代的到来,Ajax技术得到广泛应用,jQuery等前端库层出不穷,前端代码日益膨胀,此时在JS方面就会考虑使用模块化规范去管理。本文内容主要有理解模块化,为什么要模块化,模块化的优缺点以及模块化规范,并且介绍下开发中…

    2022年10月23日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号