Swift 本地推送通知UILocalNotification
Notification
是智能手机应用开发中常用的信息传递机制,它不用消耗更多资源去不停的检查信息状态,可以非常好的节省资源。
在iOS中分为两种通知:本地、远程。本地的UILocalNotification由全局的NotificationManager
统一管理,我们只需要将本地通知对象添加到系统的Notification队列中就可以了,系统会在指定的时间激发本地通知。
本地推送通知:UILocalNotification
- 如果要使用推送通知,必须先在苹果的推送通知服务里注册你要使用哪几种类型的通知,就比如下面的一段代码就表示同时注册了提醒、标记和声音两种类型的通知(ios 8之前是不需要注册的):
// 在appDelegate中注册通知
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
if #available(iOS 8.0, *) {
let uns = UIUserNotificationSettings(forTypes: [.Alert, .Badge, .Sound], categories: nil)
UIApplication.sharedApplication().registerUserNotificationSettings(uns)
}
}
2.创建并添加本地通知
class LocalNotificationUtils: NSObject {
/** 添加创建并添加本地通知 */
class func addNotification() {
// 初始化一个通知
let localNoti = UILocalNotification()
// 通知的触发时间,例如即刻起15分钟后
let fireDate = NSDate().dateByAddingTimeInterval(-15*60)
localNoti.fireDate = fireDate
// 设置时区
localNoti.timeZone = NSTimeZone.defaultTimeZone()
// 通知上显示的主题内容
localNoti.alertBody = "通知上显示的提示内容"
// 收到通知时播放的声音,默认消息声音
localNoti.soundName = UILocalNotificationDefaultSoundName
//待机界面的滑动动作提示
localNoti.alertAction = "打开应用"
// 应用程序图标右上角显示的消息数
localNoti.applicationIconBadgeNumber = 0
// 通知上绑定的其他信息,为键值对
localNoti.userInfo = ["id": "1", "name": "xxxx"]
// 添加通知到系统队列中,系统会在指定的时间触发
UIApplication.sharedApplication().scheduleLocalNotification(localNoti)
}
}
3.获取所有本地通知
let locals = UIApplication.sharedApplication().scheduledLocalNotifications
4.取消一个本地推送
// 通过通知上绑定的id来取消通知,其中id也是你在userInfo中存储的信息
class func deleteNotification(id: String) {
if orderID.isEmpty {
return
}
if let locals = UIApplication.sharedApplication().scheduledLocalNotifications {
for localNoti in locals {
if let dict = localNoti.userInfo {
if dict.keys.contains("id") && dict["id"] is String && (dict["id"] as! String) == id {
// 取消通知
UIApplication.sharedApplication().cancelLocalNotification(localNoti)
}
}
}
}
}
5.取消所有本地通知
UIApplication.sharedApplication().cancelAllLocalNotifications()
6.点击通知后的触发事件
1.应用在正在运行(在前台或后台运行),点击通知后触发appDelegate代理方法::didReceiveLocalNotification
class AppDelegate: UIResponder, UIApplicationDelegate{
/** 接收本地通知 */
func application(application: UIApplication, didReceiveLocalNotification notification: UILocalNotification) {
// 获取通知上绑定的信息
guard let dict = notification.userInfo else {
return
}
// 后面作相应处理...
}
}
2.应用未运行,点击通知启动app,走appDelegate代理方法:didFinishLaunchingWithOptions
class AppDelegate: UIResponder, UIApplicationDelegate{
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
// 省略创建window及根控制器等代码
......
// 此处只介绍当点击通知启动应用后如何获取通知
if launchOptions != nil {
if let localNotification = launchOptions!["UIApplicationLaunchOptionsLocalNotificationKey"] as? UILocalNotification {
if let dict = localNotification.userInfo {
// 获取通知上绑定的信息后作相应处理...
}
}
}
return true
}
}
参考:http://www.cnblogs.com/kenshincui/p/4168532.html#localNotification
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
2014-10-17 Android原理揭秘系列之一动态墙纸