目前有三种通知

第一种是普通通知

看看效果

布局什么的太简单了我就不放在上面了给你们看核心的代码就行了 里面的   int notificationID = 1;

//设置点击通知后的意图
Intent intent = new Intent(this,NotificationView.class);
intent.putExtra("notificationID",notificationID);
//塞入pendingIntent 参数解释:1.上下文也就是context 2.请求码(用于意图的请求码) 3.意图(用来启动目标活动的意图) 4.标志(活动启动时使用的标志)
PendingIntent pendingIntent = PendingIntent.getActivity(this,0,intent,PendingIntent.FLAG_CANCEL_CURRENT);
//获取系统的notification管理服务
NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE); //现在官方推荐用builder的方式构建Notification,原来是new的方式已经淘汰了。
Notification.Builder builder = new Notification.Builder(this);
//收到通知时最顶部显示的信息
builder.setSmallIcon(R.mipmap.ic_launcher);
builder.setTicker("Reminder:Meeting starts in 5 minutes");
builder.setWhen(System.currentTimeMillis()); //下拉顶部看到的详细通知信息 图标通用的
builder.setContentTitle("System Alarm"); //设置标题
builder.setContentText("Meeting with customer at 3pm.."); //设置内容
//设置通知被点击后的意图处理也就是打开某个activity
//至于为什么要用pendingIntent ,因为PendingIntent对象可以代表应用程序帮助您在后面的某个时候执行一个动作,而“不用考虑应用程序是否正在运行”
builder.setContentIntent(pendingIntent);
builder.setDefaults(Notification.DEFAULT_SOUND); //设置默认的声音和震动
//当然你也可以自定义设置震动
// builder.setVibrate(new long[]{100,250,100,500}); //设置震动
builder.setAutoCancel(true);//设置点击后自动消失也就是取消显示 true:点击后消失;false:点击后不消失;默认是false
Notification notif = builder.build(); //构建 这里注意build方法最低支持minSdkVersion 16
manager.notify(notificationID,notif); //notification管理服务发送你所构建的通知 此时你会收到通知

注意里面的builder.setAutoCancel(true); 如果你不想程序自动帮你点击后关闭,而是自己用代码在另一个位置自己去关闭,那么你可以不写这句代码,也可以设置成false,然后关闭代码可以这么写

        //获取服务
NotificationManager nm = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
nm.cancel(getIntent().getIntExtra("notificationID",1)); //关闭显示notificationID为1的通知

切记关闭id与你通知一致的id。

也可以写个方法

/**
* 显示普通的通知
*/
private void showNormalNotify(){
Notification.Builder builder = new Notification.Builder(this);
builder.setAutoCancel(true); //设置点击玩自动关闭
builder.setSmallIcon(R.drawable.ic_launcher_background);
builder.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.drawable.ic_launcher_foreground));
builder.setContentTitle("普通通知");
builder.setContentText("普通通知的我的鬼内容");
Intent intent = new Intent(Intent.ACTION_VIEW,Uri.parse("http://www.baidu.com"));
PendingIntent pendingIntent = PendingIntent.getActivity(this,0,intent,0);
builder.setContentIntent(pendingIntent); NotificationManager notifiyManager = (NotificationManager) this.getSystemService(Context.NOTIFICATION_SERVICE);
notifiyManager.notify(1,builder.build());
}

第二种是折叠式的通知

看看效果

写法也是类似只是需要用到红色标注的代码

 /**
* 显示折叠式的通知
*/
@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
private void showZDNotify(){ Notification.Builder builder = new Notification.Builder(this);
builder.setAutoCancel(true);
builder.setSmallIcon(R.drawable.ic_launcher_background);
builder.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.drawable.ic_launcher_foreground));
builder.setContentTitle("折叠式通知");
builder.setContentText("这是折叠式通知");
Intent intent = new Intent(Intent.ACTION_VIEW,Uri.parse("http://www.baidu.com"));
PendingIntent pendingIntent = PendingIntent.getActivity(this,0,intent,0);
builder.setContentIntent(pendingIntent); RemoteViews remoteViews = new RemoteViews(getPackageName(),R.layout.view_fold);
Notification notification = builder.build();
notification.bigContentView = remoteViews; NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);;
notificationManager.notify(1,notification);
}

第三种是悬挂式通知

看看效果

来看看使用方法

写法也是类似只是需要用到红色标注的代码

/**
* 显示悬挂式的通知
*/
private void showXGNotify(){
Notification.Builder builder = new Notification.Builder(this);
builder.setAutoCancel(true);
builder.setSmallIcon(R.drawable.ic_launcher_background);
builder.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.drawable.folder));
builder.setContentTitle("悬挂式通知");
builder.setContentText("这是折叠式通知");
Intent intent = new Intent();
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.setClass(this,TestActivity.class);
PendingIntent hangPendingIntent = PendingIntent.getActivity(this,0,intent,PendingIntent.FLAG_CANCEL_CURRENT);
builder.setFullScreenIntent(hangPendingIntent,true);
NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
notificationManager.notify(1,builder.build());
}

Android 5.0后加入了一种新的模式Notification显示等级,共有以下3种

1.VISIBILITY_PUBLIC:任何情况都会显示通知

2.VISIBILITY_PRIVATE:只有在没有锁屏时会显示通知。

3.VISIBILITY_SECRET:在pin、password等安全锁和没有锁屏的情况下才能显示通知

设置非常简单,只要调用setVisibility方法就行了

builder.setVisibility(Notification.VISIBILITY_PUBLIC);

是不是很简单。

好了,好好学习天天向上。

学习记录,如果有错请指出,谢谢!

从零开始学android -- notification通知的更多相关文章

  1. Android Notification通知详细解释

    Android Notification通知具体解释  Notification: (一).简单介绍:         显示在手机状态栏的通知. Notification所代表的是一种具有全局效果的通 ...

  2. Android Notification通知简介

    Android Notification通知简介 根据activity的生命周期,在activity不显示时,会执行onStop函数(比如按下home键),所以你在onStop函数(按退出键除外)里面 ...

  3. Android Notification通知详解

    根据activity的生命周期,在activity不显示时,会执行onStop函数(比如按下home键),所以你在onStop函数(按退出键除外)里面把notification放在通知栏里,再此显示时 ...

  4. Android Notification通知

    /** * 在状态栏显示通知 */ private void showNotification(){ // 创建一个NotificationManager的引用 NotificationManager ...

  5. 从零开始学android -- Service

    废话不多说了,Service是四大组件之一,是一个后台处理长时间运行在主线程不需要依赖ui界面显示的应用组件,切记不能在service中做耗时操作,会阻塞主线程,要做也要在service中开个子线程做 ...

  6. 从零开始学android开发-项目打包发布

    右键项目 选择[android tools]-[export signed application package] 点击[next] 如果没有keystore可以选择[create new keys ...

  7. 从零开始学android开发-adt-bundle-eclipse下的修改android app名称

    eclipse中,打开项目根目录中的AndoirManifest.xml文件,找到如下内容 <application android:allowBackup="true" a ...

  8. 从零开始学android开发-通过WebService进行网络编程,使用工具类轻松实现

    相信大家在平常的开发中,对网络的操作用到HTTP协议比较多,通过我们使用Get或者Post的方法调用一个数据接口,然后服务器给我们返回JSON格式的数据,我们解析JSON数据然后展现给用户,相信很多人 ...

  9. 从零开始学android开发-通过WebService获取今日天气情况

    因为本身是在搞.NET方面的东东,现在在学习Android,所以想实现Android通过WebService接口来获取数据,网上很多例子还有有问题的.参考:Android 通过WebService进行 ...

随机推荐

  1. linux 服务器信息查看

    写项目总结报告,需要统计需要系统的配合 1.# uname -a   (Linux查看版本当前操作系统内核信息) Linux localhost.localdomain 2.4.20-8 #1 Thu ...

  2. 关于MySQL Cluster集群NoOfReplicas参数问题

    摘自:http://www.itpub.net/thread-1845295-1-1.html 官方网站上说参数NoOfReplicas的值表示数据的备份份数,例如:NoOfReplicas=2,若在 ...

  3. 什么是IIS并发连接数

    http://blog.csdn.net/leftfist/article/details/38407223  https://wk.baidu.com/view/2962d073f242336c1e ...

  4. Delphi CRC16校验算法实现(转)

    循环冗余码校验英文名称为Cyclical Redundancy Check,简称CRC.它是利用除法及余数的原理来作错误侦测(Error Detecting)的.实际应用时,发送装置计算出CRC值并随 ...

  5. ServicePointManager.ServerCertificateValidationCallback 冲突的解决

    ServicePointManager是用于创建. 维护和删除的实例的静态类ServicePoint类. 当应用程序请求对 Internet 资源统一资源标识符 (URI) 的连接通过ServiceP ...

  6. kubernetes--pod的生命周期管理

    下文基于kubernetes 1.5.2版本编写 lifecycle 概念 创建资源对象时,可以使用lifecycle来管理容器在运行前和关闭前的一些动作. lifecycle有两种回调函数: Pos ...

  7. 设计模式之桥接模式(php实现)

    github地址:https://github.com/ZQCard/design_pattern /** * 桥接模式 * 优点: * 1.分离抽象接口及其实现部分.提高了比继承更好的解决方案. * ...

  8. swift初探(供objective c开发人员參考)

    6月初的wwdc苹果推出了一门新的开发语言swift.系统10.9.3以上安装xcode6 beta版就可以体验swift. 苹果公司做了尽可能多的努力让这门语言迅速成为一个工业级的有用编程语言,而不 ...

  9. 使用springMVC上传文件

    control层实现功能: @RequestMapping(value="upload2") public String upLoad2(HttpServletRequest re ...

  10. ElasticSearch _xpack角色管理

    权限管理可以通过kibana的Management界面进行,本篇主要介绍的是通过命令进行,角色API使您能够在本机域中添加,删除和检索角色. 要使用此API,您必须至少具有manage_securit ...