位置: 编程技术 - 正文

Android中通知的使用-----Notification详解(android通知消息)

编辑:rootadmin

推荐整理分享Android中通知的使用-----Notification详解(android通知消息),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:android 通知管理,安卓通知类型,安卓通知类型,android系统的通知,android系统设置通知管理,安卓通知app,安卓通知类型,安卓通知机制,内容如对您有帮助,希望把文章链接给更多的朋友!

Notification —— 通知,是一种让你的应用程序在不使用Activity的情况下警示用户。它是看不见的程序组件(Broadcast Receiver,Service和不活跃的Activity)警示用户有需要注意的事件发生的最好途径。 Notification 是由NotificationManager(系统服务)统一管理的。

一般来说, 一个Notification应该传送的消息包括:

1 、一个状态条图标

2、在拉伸的状态栏窗口中显示额外的信息和启动一个Application的Intent

3、闪灯或LED

4、电话震动

在状态栏(Status Bar)中,通知主要有两类(使用FLAG_标记,后面讲解到):

1、正在运行的事件

2、通知事件

Notification图解如下:

Notification类介绍:

常量:

//表示发送一个Notification的所携带的效果

DEFAULT_ALL 使用默认字段

DEFAULT_LIGHTS 默认闪光

DEFAULT_SOUND 默认声音(uri,指向路径)

DEFAULT_VIRATE 默认震动,后来得知需要添加震动权限VIBRATE: android.permission.VIBRATE

PS:以上的效果常量可以累加,即通过mNotifaction.defaults |=DEFAULT_SOUND (有些效果只能在真机上才有,比如震动)

//设置Flag位

FLAG_AUTO_CANCEL 该通知能被状态栏的清除按钮给清除掉

FLAG_NO_CLEAR 该通知不能被状态栏的清除按钮给清除掉

FLAG_ONGOING_EVENT 通知放置在正在运行

常用字段

contentView 通知在状态栏的显示View(自定义,具体请看下文) ,常与contentIntent配合使用,点击该通知后,

即触发contentIntent

contentIntent 设置PendingIntent对象,点击该通知时发送该Intent

flags 设置flag位,例如FLAG_NO_CLEAR等

defaults 添加效果

tickerText 显示在状态栏中的文字

when 发送此通知的时间戳

icon 设置图标

Android中通知的使用-----Notification详解(android通知消息)

常用方法介绍:

void setLatestEventInfo(Context context , CharSequence contentTitle,CharSequence contentText,PendingIntent contentIntent)

功能: 显示在拉伸状态栏中的Notification属性,点击后将发送PendingIntent对象。

参数: context 上下文环境

contentTitle 状态栏中的大标题

contentText 状态栏中的小标题

contentIntent 点击后将发送PendingIntent对象

另外的就是Notification的几步不同构造方法了,其构造方法的参数含义如上,请参考SDK 。

注意,关于通知(Notification)的显示类型有两种:

第一种:使用默认的形式(效果图如上显示)。具体使用是为Notification对象设置setLatestEventInfo()方法(该方法内部创建

了默认的RemoteViews对象,因此为默认显示),否则程序会报异常 ;

第二种: 使用自定义的View(RemoteViews对象)显示(功能更加自由,强大),具体方法为设置Notification对象的

contentView 属性和contentIntent属性 ,此时不需要设置setLatestEventInfo()方法。具体使用方法如下:

[java] view plaincopyNotification noti = new Notification(icon, title, when &#; ); noti.flags = Notification.FLAG_INSISTENT; // 1、创建一个自定义的消息布局 notification.xml // 2、在程序代码中使用RemoteViews的方法来定义image和text。然后把RemoteViews对象传到contentView字段 RemoteViews remoteView = new RemoteViews(this.getPackageName(),R.layout.notification); remoteView.setImageViewResource(R.id.image, R.drawable.icon); remoteView.setTextViewText(R.id.text , "Hello,this message is in a custom expanded view"); noti.contentView = remoteView; // 3、为Notification的contentIntent字段定义一个Intent(注意,使用自定义View不需要setLatestEventInfo()方法) //这儿点击后简答启动Settings模块 PendingIntent contentIntent = PendingIntent.getActivity (MainActivity.this, 0,new Intent("android.settings.SETTINGS"), 0); noti.contentIntent = contentIntent;

本文采用的RemoteViews资源文件如下:/layout/notification.xml

[java] view plaincopy<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android=" android:orientation="horizontal" android:layout_width="fill_parent" android:layout_height="fill_parent"> <ImageView android:id="@&#;id/image" android:layout_width="wrap_content" android:layout_height="fill_parent" /> <TextView android:id="@&#;id/text" android:layout_width="wrap_content" android:layout_toRightOf="@&#;id/image" android:layout_height="wrap_content" android:textColor="#" /> <ProgressBar android:id="@&#;id/progress_horizontal" style="?android:attr/progressBarStyleHorizontal" android:layout_below="@&#;id/text" android:layout_toRightOf="@&#;id/image" android:layout_width="fill_parent" android:layout_height="wrap_content" android:max="" android:progress="" android:secondaryProgress="" /> </RelativeLayout>

效果图如下:

前面我们说过,NotificationManager是所有Notification的大管家,它的主要职责是加入/移除Notification。

NotificationManager类

通过获取系统服务来获取该对象:

NotificationManager mNotificationManager = (NotificationManager)getSystemServic(Context.NOTIFICATION_SERVICE) ;

常用方法:

public void cancelAll() 移除所有通知 (只是针对当前Context下的Notification)

public void cancel(int id) 移除标记为id的通知 (只是针对当前Context下的所有Notification)

public void notify(String tag ,int id, Notification notification) 将通知加入状态栏, 标签为tag,标记为id

public void notify(int id, Notification notification) 将通知加入状态栏,,标记为id

Demo如下:

说明: 示例Demo演示了创建两种不同类型的Notification , 实现起来也是很简单的。其实说到两种不同类型的使用

方式 ,其实内部原理是差不多的。

PS : 自定义Notification复用了文章之前的布局文件,请知晓。

[java] view plaincopypackage com.feixun.qin; import android.app.Activity; import android.app.Notification; import android.app.NotificationManager; import android.app.PendingIntent; import android.content.BroadcastReceiver; import android.content.Context; import android.content.Intent; import android.content.IntentFilter; import android.net.Uri; import android.os.Bundle; import android.provider.MediaStore.Audio; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.RemoteViews; import android.widget.RemoteViews.RemoteView; public class MainActivity extends Activity { private Button sendNotiBt; private int count = 0; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); sendNotiBt = (Button) findViewById(R.id.sendNotiBt); sendNotiBt.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub showDefaultNotification(); } }); } //自定义显示的通知 ,创建RemoteView对象 private void showCustomizeNotification() { CharSequence title = "i am new"; int icon = R.drawable.icon; long when = System.currentTimeMillis(); Notification noti = new Notification(icon, title, when &#; ); noti.flags = Notification.FLAG_INSISTENT; // 1、创建一个自定义的消息布局 view.xml // 2、在程序代码中使用RemoteViews的方法来定义image和text。然后把RemoteViews对象传到contentView字段 RemoteViews remoteView = new RemoteViews(this.getPackageName(),R.layout.notification); remoteView.setImageViewResource(R.id.image, R.drawable.icon); remoteView.setTextViewText(R.id.text , "通知类型为:自定义View"); noti.contentView = remoteView; // 3、为Notification的contentIntent字段定义一个Intent(注意,使用自定义View不需要setLatestEventInfo()方法) //这儿点击后简单启动Settings模块 PendingIntent contentIntent = PendingIntent.getActivity (MainActivity.this, 0,new Intent("android.settings.SETTINGS"), 0); noti.contentIntent = contentIntent; NotificationManager mnotiManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); mnotiManager.notify(0, noti); } // 默认显示的的Notification private void showDefaultNotification() { // 定义Notication的各种属性 CharSequence title = "i am new"; int icon = R.drawable.icon; long when = System.currentTimeMillis(); Notification noti = new Notification(icon, title, when &#; ); noti.flags = Notification.FLAG_INSISTENT; // 创建一个通知 Notification mNotification = new Notification(); // 设置属性&#; mNotification.icon = R.drawable.icon; mNotification.tickerText = "NotificationTest"; mNotification.when = System.currentTimeMillis(); // 立即发生此通知 // 带参数的构造函数,属性&#;如上 // Notification mNotification = = new Notification(R.drawable.icon,"NotificationTest", System.currentTimeMillis())); // 添加声音效果 mNotification.defaults |= Notification.DEFAULT_SOUND; // 添加震动,后来得知需要添加震动权限 : Virbate Permission //mNotification.defaults |= Notification.DEFAULT_VIBRATE ; //添加状态标志 //FLAG_AUTO_CANCEL 该通知能被状态栏的清除按钮给清除掉 //FLAG_NO_CLEAR 该通知能被状态栏的清除按钮给清除掉 //FLAG_ONGOING_EVENT 通知放置在正在运行 //FLAG_INSISTENT 通知的音乐效果一直播放 mNotification.flags = Notification.FLAG_INSISTENT ; //将该通知显示为默认View PendingIntent contentIntent = PendingIntent.getActivity (MainActivity.this, 0,new Intent("android.settings.SETTINGS"), 0); mNotification.setLatestEventInfo(MainActivity.this, "通知类型:默认View", "一般般哟。。。。",contentIntent); // 设置setLatestEventInfo方法,如果不设置会App报错异常 NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); //注册此通知 // 如果该NOTIFICATION_ID的通知已存在,会显示最新通知的相关信息 ,比如tickerText 等 mNotificationManager.notify(2, mNotification); } private void removeNotification() { NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); // 取消的只是当前Context的Notification mNotificationManager.cancel(2); } }

简单粗暴的图片压缩,可以压到kb以内 publicstaticBitmaprevitionImageSize(Stringpath)throwsIOException{BufferedInputStreamin=newBufferedInputStream(newFileInputStream(newFile(path)));BitmapFactory.Optionsoptions=newBitmapFactory.Options()

Android gpio口在sys_comfig中的参数意义 ;Port:端口组内序号功能分配内部电阻状态驱动能力输出电平状态;第一个尖括号:功能分配,0为输入,1为输出,2是可做IO口,6是中断口,其余不确定;第

在Android中实现截图功能 在实际应用中,经常需要对图片进行处理,包括压缩、截图等等,其实android系统提供了一个可以截图的activity,我们只需调用它就行了,下面示例完成

标签: android通知消息

本文链接地址:https://www.jiuchutong.com/biancheng/370942.html 转载请保留说明!

上一篇:Android使用volley发送带参数的post请求(Android使用活动需要去什么进行注册)

下一篇:简单粗暴的图片压缩,可以压到100kb以内(简单 粗暴)

  • 个体工商户缴纳税目
  • 一般纳税人服务费税率
  • 进料加工出口退税政策
  • 收取境外技术服务费如何
  • 其他应收款要做账吗
  • 一般纳税人变成小规模 在电子税务局哪里可以找到
  • 使用权资产是什么类科目
  • 银行贷款受托支付后,钱怎么转回来
  • 资产减值损失借贷方向
  • 房产折旧计算方法 举例
  • 向其他单位无偿提供服务的不需缴纳增值税
  • 出纳长短款项应按日结清,但不需要计算
  • 企业所得税的减按征收如何计算
  • 个人所得税申报方式选哪个
  • 营改增后房产税计税依据 土地价款
  • 一个项目可以有几个单位工程
  • 以前年度已经缴纳的税
  • 企业会计准则应用案例
  • 本月只有红字发票该怎么申报小规模
  • 接受无形资产投资进项税
  • 现金购入库存商品的分录
  • 政府委托代建的房地产公司是否可以开立农民工工资
  • 异常抵扣凭证进项税转出入哪个所属期
  • 2019年小微企业增值税起征点为月销售额
  • wifi上传速度为0的解决方法
  • 忘记excel工作表保护密码怎么办
  • 把试驾车当新车卖,构成欺诈
  • 这张磁盘有写保护无法格式化
  • 网速变慢了
  • 发出商品但货款没到账
  • 增值税发票销货清单哪里领
  • php中session什么意思
  • 收取跨年租金会计处理
  • 税务 终结执行
  • php的二维数组
  • 批发商和零售商属于
  • vue fragment标签
  • vue安装使用
  • JavaScript(WebAPI)+具体案例
  • 小企业短期借款科目的贷方登记
  • 装修的工程款账务处理
  • SQL Server FileStream详解
  • 制造费用结转本年利润吗
  • 采购原材料凭证是什么
  • access数据库用户名和密码
  • 资产损失税前扣除
  • 微信,支付宝等第三方支付对货币的影响
  • 货款已退回货已收到怎么办
  • 2021年购买土地需要缴纳什么税
  • 已认证的红字发票怎么开
  • 关于发放节日补助的通知
  • 新注册的公司在企查查上查不到
  • 支付货款订金入什么科目
  • 销售返利是否需要交税
  • 母公司和子公司是两个完全独立的法人
  • 国税退回多缴税款
  • 如何登录网络?
  • mysql -ne
  • mysql报错1091
  • win8.1补丁打不上
  • win10预览版好吗
  • centos7 pptp搭建
  • u启动如何装系统
  • 苹果mac怎么查看运行数据
  • Retina MacBook和10.10.3支持更快的NVMe SSD接口
  • windows8锁屏
  • win7系统360浏览器书签
  • win10桌面预览功能怎么打开
  • win10mobile官网
  • opengl网格
  • linux升级python2.7
  • 7z.exe 命令行
  • 用jquery制作网页
  • 从零开始学什么好
  • node.js django
  • 防止shell脚本重复执行
  • javascript类库
  • 土地税源编码怎么填
  • 国税申报密码可以输几次
  • 爱山东怎样查询医保余额
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设