轻松搞定iOS本地消息推送
首先,我们先要明白一个概念,这里的本地通知是uilocalnotification类,和系统的nsnotificationcenter通知中心是完全不同的概念。
一、我们可以通过本地通知做什么
通知,实际上是由ios系统管理的一个功能,比如某些后台应用做了某项活动需要我们处理、已经退出的应用在某个时间提醒我们唤起等等,如果注册了通知,系统都会在通知触发时给我们发送消息。由此,我们可以通过系统给我们的app添加通知用户的功能,并且应用非常广泛。例如,闹种类应用,有按时签到相似功能的应用。下面,我们就来介绍如何注册并且设置一个本地通知。
二、了解uilocalnotification类
顾名思义,这个类就是我们需要使用的本地通知类,先来看它的几个属性:
设置系统发送通知的时间(如果是过去的时间或者0,则会立刻发起通知)
@property(nonatomic,copy) nsdate *firedate;
设置时间的时区
@property(nonatomic,copy) nstimezone *timezone;
设置周期性通知
@property(nonatomic) nscalendarunit repeatinterval;
nscalendarunit对象是枚举,设定通知的周期
typedef ns_options(nsuinteger, nscalendarunit) { nscalendarunitera = kcfcalendarunitera, nscalendarunityear = kcfcalendarunityear, nscalendarunitmonth = kcfcalendarunitmonth, nscalendarunitday = kcfcalendarunitday, nscalendarunithour = kcfcalendarunithour, nscalendarunitminute = kcfcalendarunitminute, nscalendarunitsecond = kcfcalendarunitsecond, nscalendarunitweekday = kcfcalendarunitweekday, nscalendarunitweekdayordinal = kcfcalendarunitweekdayordinal, }
设置周期性通知参照的日历表
@property(nonatomic,copy) nscalendar *repeatcalendar;
下面这两个函数是ios8的新功能,在用户进去或者离开某一区域时发送通知
@property(nonatomic,copy) clregion *region;
设置区域检测通知是否重复(如果为yes,则没次进去出来都会发送,否则只发送一次)
@property(nonatomic,assign) bool regiontriggersonce;
设置通知的主体内容
@property(nonatomic,copy) nsstring *alertbody;
是否隐藏滑动启动按钮
@property(nonatomic) bool hasaction;
设置滑动打开的提示文字
@property(nonatomic,copy) nsstring *alertaction;
设置点击通知后启动的启动图片
@property(nonatomic,copy) nsstring *alertlaunchimage;
下面这个方法是ios8的新方法,是iwatch的接口,通知的短标题
@property(nonatomic,copy) nsstring *alerttitle;
收到通知时,播放的系统音
@property(nonatomic,copy) nsstring *soundname;
设置应用程序icon头标数字
@property(nonatomic) nsinteger applicationiconbadgenumber;
用户字典,可用于传递通知消息参数
@property(nonatomic,copy) nsdictionary *userinfo;
注意:这个字符串是系统默认的提示音
nsstring *const uilocalnotificationdefaultsoundname;
三、本地通知的设计流程
首先,想让我们的app实现本地通知功能,必须得到用户的授权,在appdelegate中实现如下代码:
- (bool)application:(uiapplication *)application didfinishlaunchingwithoptions:(nsdictionary *)launchoptions { // override point for customization after application launch. //如果已经得到授权,就直接添加本地通知,否则申请询问授权 if ([[uiapplication sharedapplication]currentusernotificationsettings].types!=uiusernotificationtypenone) { [self addlocalnotification]; }else{ [[uiapplication sharedapplication]registerusernotificationsettings:[uiusernotificationsettings settingsfortypes:uiusernotificationtypealert|uiusernotificationtypebadge|uiusernotificationtypesound categories:nil]]; } return yes; }
当用户点击允许或者不允许后,会执行如下代理方法,我们把处理逻辑在其中实现
-(void)application:(uiapplication *)application didregisterusernotificationsettings:(uiusernotificationsettings *)notificationsettings{ if (notificationsettings.types!=uiusernotificationtypenone) { [self addlocalnotification]; } }
添加本地通知的方法:
-(void)addlocalnotification{ //定义本地通知对象 uilocalnotification *notification=[[uilocalnotification alloc]init]; //设置调用时间 notification.firedate=[nsdate datewithtimeintervalsincenow:0];//立即触发 //设置通知属性 notification.alertbody=@"hello,我是本地通知哦!"; //通知主体 notification.applicationiconbadgenumber=1;//应用程序图标右上角显示的消息数 notification.alertaction=@"打开应用"; //待机界面的滑动动作提示 notification.soundname=uilocalnotificationdefaultsoundname;//收到通知时播放的声音,默认消息声音 //调用通知 [[uiapplication sharedapplication] schedulelocalnotification:notification]; }
实现了上面三个步骤,本地通知的发出和接受基本都已完成,还有一些细节我们需要考虑:
应用进入前台后,将icon上的头标清除:
-(void)applicationwillenterforeground:(uiapplication *)application{ [[uiapplication sharedapplication]setapplicationiconbadgenumber:0];//进入前台取消应用消息图标 }
当不再需要这个通知时,清除它
[[uiapplication sharedapplication] cancelalllocalnotifications];
四、获取通知中的用户参数字典
在上面,我们提到了一个参数
@property(nonatomic,copy) nsdictionary *userinfo;
我们可以在注册通知时将这个参数设置,然后在收到通知时使用get方法得到,但是这里有两种情况:
1、如果我们的app在前台或者后台进入前台时
这个方法是app在前台或者后台收到通知进入前台时调用的方法
2、如果我们的app在关闭状态
如果是这种情况,我们只能从下面函数的launchoptions中取到我们想要的参数
代码示例如下:
//接收通知参数 uilocalnotification *notification=[launchoptions valueforkey:uiapplicationlaunchoptionslocalnotificationkey]; nsdictionary *userinfo= notification.userinfo;
本文已被整理到了《ios推送教程》,欢迎大家学习阅读。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。