这两天在做一个日程提醒功能,用到了本地通知的功能,记录相关知识如下:
1、本地通知的定义和使用:
本地通知是UILocalNotification的实例,主要有三类属性:
scheduled time,时间周期,用来指定iOS系统发送通知的日期和时间;
notification type,通知类型,包括警告信息、动作按钮的标题、应用图标上的badge(数字标记)和播放的声音;
自定义数据,本地通知可以包含一个dictionary类型的本地数据。
对本地通知的数量限制,iOS最多允许最近本地通知数量是64个,超过限制的本地通知将被iOS忽略。
代码如下 |
复制代码 |
UILocalNotification *localNotification = [[UILocalNotification alloc] init]; if (localNotification == nil) { return; } //设置本地通知的触发时间(如果要立即触发,无需设置),这里设置为20妙后 localNotification.fireDate = [NSDate dateWithTimeIntervalSinceNow:20]; //设置本地通知的时区 localNotification.timeZone = [NSTimeZone defaultTimeZone]; //设置通知的内容 localNotification.alertBody = affair.title; //设置通知动作按钮的标题 localNotification.alertAction = @"查看”; //设置提醒的声音,可以自己添加声音文件,这里设置为默认提示声 localNotification.soundName = UILocalNotificationDefaultSoundName; //设置通知的相关信息,这个很重要,可以添加一些标记性内容,方便以后区分和获取通知的信息 NSDictionary *infoDic = [NSDictionary dictionaryWithObjectsAndKeys:LOCAL_NOTIFY_SCHEDULE_ID,@"id",[NSNumber numberWithInteger:time],@"time",[NSNumber numberWithInt:affair.aid],@"affair.aid", nil]; localNotification.userInfo = infoDic; //在规定的日期触发通知 [[UIApplication sharedApplication] scheduleLocalNotification:localNotification]; //立即触发一个通知 // [[UIApplication sharedApplication] presentLocalNotificationNow:localNotification]; [localNotification release];
|
2、取消本地通知:
代码如下 |
复制代码 |
//取消某一个通知 NSArray *notificaitons = [[UIApplication sharedApplication] scheduledLocalNotifications]; //获取当前所有的本地通知 if (!notificaitons || notificaitons.count <= 0) { return; } for (UILocalNotification *notify in notificaitons) { if ([[notify.userInfo objectForKey:@"id"] isEqualToString:LOCAL_NOTIFY_SCHEDULE_ID]) { //取消一个特定的通知 [[UIApplication sharedApplication] cancelLocalNotification:notify]; break; } } //取消所有的本地通知 [[UIApplication sharedApplication] cancelAllLocalNotifications];
|
3、本地通知的响应:
如果已经注册了本地通知,当客户端响应通知时:
a、应用程序在后台的时候,本地通知会给设备送达一个和远程通知一样的提醒,提醒的样式由用户在手机设置中设置
b、应用程序正在运行中,则设备不会收到提醒,但是会走应用程序delegate中的方法:
代码如下 |
复制代码 |
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification { }
|
,如果你想实现程序在后台时候的那种提醒效果,可以在上面这个方法中添加相关代码,示例代码:
代码如下 |
复制代码 |
if ([[notification.userInfo objectForKey:@"id"] isEqualToString:@"affair.schedule"]) { UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"test" message:notification.alertBody delegate:nil cancelButtonTitle:@"关闭" otherButtonTitles:notification.alertAction, nil nil]; [alert show]; }
|
需要注意的是,在情况a中,如果用户点击提醒进入应用程序,也会执行收到本地通知的回调方法,这种情况下如果你添加了上面那段代码,则会出现连续出现两次提示,为了解决这个问题,修改代码如下:
代码如下 |
复制代码 |
if ([[notification.userInfo objectForKey:@"id"] isEqualToString:@"affair.schedule"]) { //判断应用程序当前的运行状态,如果是激活状态,则进行提醒,否则不提醒 if (application.applicationState == UIApplicationStateActive) { UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"test" message:notification.alertBody delegate:nil cancelButtonTitle:@"关闭" otherButtonTitles:notification.alertAction, nil nil]; [alert show]; } }
|
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· 使用C#创建一个MCP客户端
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· Windows编程----内核对象竟然如此简单?