1.请求通知权限
// 请求通知权限
UNUserNotificationCenter.current().requestAuthorization(options: [.alert,.badge,.sound,.criticalAlert]) { (granted: Bool, error: Error?) in
if !granted {
print("用户不允许消息通知。")
}
}
let center = UNUserNotificationCenter.current()
// 通知中心代理
center.delegate = self
// 获取当前的通知设置,UNNotificationSettings 是只读对象,不能直接修改,只能通过以下方法获取
center.getNotificationSettings { (settings: UNNotificationSettings) in
}
2.创建一个新的通知内容 UNMutableNotificationContent ,我们先了解一下这个类
// 为通知中附加音频,图片,视频
open var attachments: [UNNotificationAttachment]
// 控制应用的badge的数量。nil意味着没有改变。0隐藏
@NSCopying open var badge: NSNumber?
// 通知消息主体
open var body: String
// 通知标识符,在通知代理 中用来识别具体是哪一个通知
open var categoryIdentifier: String
// 从通知打开应用程序时将使用的启动图像,通知中有图片时,设置本属性,可以获取下拉图片的大图展示
open var launchImageName: String
// 通知的提示音,可以默认系统的defaultSound ; 也可以加载本地的音频文件(传入音频文件名)
@NSCopying open var sound: UNNotificationSound?
// 通知的副标题
open var subtitle: String
// 线程标识
open var threadIdentifier: String
// 通知标题
open var title: String
// 当一个通知发出时携带的信息;(远程时用到)
open var userInfo: [AnyHashable : Any]
// 要插入此通知的摘要中的参数
@available(iOS 12.0, *)
open var summaryArgument: String
// 一个数字,指示摘要中有多少项在摘要中表示。例如,如果播客应用为一个节目中的3个新剧集发送一个通知,则参数应为节目名称,计数应为3。默认值为1,不能为0。
@available(iOS 12.0, *)
open var summaryArgumentCount: Int
3.创建和发送通知
// 通知内容设置
let content = UNMutableNotificationContent()
content.title = "推送标题"
content.subtitle = "推送子标题"
content.body = "推送消息主体内容"
content.badge = 2 // 图标右上角数字
content.categoryIdentifier = "categoryIdentifier" // 通知标识
content.sound = UNNotificationSound.default // 推送声音
content.launchImageName = "hema.png" // 启动图片
do {
/*
在创建附件的方法:
(1)URL必须是一个有效地文件路径,
(2)option 是共有4个选项,
UNNotificationAttachmentOptionsTypeHintKey: 如果添加附件的文件名字中没有类型,就要靠该键值来确定文件类型;
UNNotificationAttachmentOptionsThumbnailHiddenKey: 是一个BOOL值,为YES时候,缩略图将隐藏,默认为YES;
UNNotificationAttachmentOptionsThumbnailClippingRectKey: 是一个矩形CGRect 剪贴图片的缩略图的键值;
UNNotificationAttachmentOptionsThumbnailTimeKey: 如果附件是一个视频的话,可以用这值来指定视频中的某一秒为视频的缩略图
*/
// 设置通知下拉的图片,可以是图片,视频,音频
let attachment = try UNNotificationAttachment(identifier: "note1", url: URL(fileURLWithPath: Bundle.main.path(forResource: "hema", ofType: ".png")!), options: nil)
content.attachments = [attachment]
} catch {
print(error)
}
// 通知下拉时候的动作
let action = UNNotificationAction(identifier: "action", title: "进入应用", options: UNNotificationActionOptions.foreground)
let clearAction = UNNotificationAction(identifier: "clearaction", title: "忽略", options: UNNotificationActionOptions.destructive)
let category = UNNotificationCategory(identifier: "categoryIdentifier", actions: [action,clearAction], intentIdentifiers: [], options: [])
center.setNotificationCategories([category])
///1,一段时间后触发(UNTimeIntervalNotificationTrigger)
// 通知触发器,10秒触发
let timeTrigger = UNTimeIntervalNotificationTrigger(timeInterval: 5, repeats: false)
/* 2.指定日期时间触发(UNCalendarNotificationTrigger)
// 下面代码我们设置2019年11月11日凌晨触发推送通知。
var components = DateComponents()
components.year = 2019
components.month = 11
components.day = 11
let trigger = UNCalendarNotificationTrigger(dateMatching: components, repeats: false)
// 下面代码我们设置每周一上午8点都会触发推送通知。
var components = DateComponents()
components.weekday = 2 //周一
components.hour = 8 //上午8点
components.second = 30 //30分
let trigger = UNCalendarNotificationTrigger(dateMatching: components, repeats: true)
*/
/* 3,根据位置触发(UNLocationNotificationTrigger)
// 该触发器支持进入某地触发、离开某地触发、或者两种情况均触发。下面代码设置成当手机进入到指定点(纬度:52.10,经度:51.11)200 米范围内时会触发推送通知。(注意:这里我们需要 import CoreLocation 框架)
let coordinate = CLLocationCoordinate2D(latitude: 52.10, longitude: 51.11)
let region = CLCircularRegion(center: coordinate, radius: 200, identifier: "center")
region.notifyOnEntry = true //进入此范围触发
region.notifyOnExit = false //离开此范围不触发
let trigger = UNLocationNotificationTrigger(region: region, repeats: true)
*/
// 请求标识符
let requestidentifier = "requestidentifier"
let request = UNNotificationRequest(identifier: requestidentifier, content: content, trigger: timeTrigger)
// 将通知请求添加到发送中心
center.add(request) { (error: Error?) in
}
4.代理
// 将要通知
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
print("willPresent")
}
// 已经完成推送
func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void) {
print("didReceive")
completionHandler()
}