iWatch同步接收連接手機的通知球涛,查看起來非常方便。像微信這種及時通訊消息的通知還有快捷回復(fù)拿撩,更方便。接下來就說說如何實現(xiàn)在iWatch的通知中心實現(xiàn)信息的快捷回復(fù)如蚜。
要實現(xiàn)這一功能需要iOS10以上系統(tǒng)压恒,因為用到了UserNotifications framework
這個框架。UserNotifications framework
讓開發(fā)者可以更多樣的實現(xiàn)通知界面错邦。詳細使用可查看這篇文章探赫。
實現(xiàn)這一功能主要有3步:
1>注冊自定義通知操作類型
2>請求本地和遠程通知的交互操作授權(quán)
3>接收到自定義的通知時實現(xiàn)自定義操作
一、注冊自定義通知操作類型
在程序入口方法- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
中注冊自定義操作撬呢。為了代碼整潔這部分功能做了封裝伦吠,封裝為一個NotificationHandle
類。
在NotificationHandle
類 的registerNotificationCategory
方法中做了注冊自定義操作魂拦,代碼如下毛仪。
//注冊通知中的action事件
-(void)registerNotificationCategory{
//帶回復(fù)的通知事件注冊
UNTextInputNotificationAction *replyAction = [UNTextInputNotificationAction actionWithIdentifier:@"replyClick" title:@"回復(fù)" options:UNNotificationActionOptionAuthenticationRequired textInputButtonTitle:@"發(fā)送" textInputPlaceholder:@"請輸入評論內(nèi)容.."];
UNNotificationCategory *tapCategory = [UNNotificationCategory categoryWithIdentifier:@"reply" actions:@[replyAction] intentIdentifiers:@[] options:UNNotificationCategoryOptionCustomDismissAction];
NSSet *set = [[NSSet alloc]initWithObjects:tapCategory, nil];
[[UNUserNotificationCenter currentNotificationCenter] setNotificationCategories:set];
}
二、請求本地和遠程通知的交互操作授權(quán)
-(void)authorizationPushNotificaton:(UIApplication *)application{
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
center.delegate = self; //必須寫代理
[center requestAuthorizationWithOptions:UNAuthorizationOptionBadge | UNAuthorizationOptionSound | UNAuthorizationOptionAlert | UNAuthorizationOptionCarPlay completionHandler:^(BOOL granted, NSError * _Nullable error) {
//注冊之后的回調(diào)
if (!error && granted) {
NSLog(@"注冊成功...");
}
else{
NSLog(@"注冊失敗...");
}
}];
//獲取注冊之后的權(quán)限設(shè)置
//之前注冊推送服務(wù)芯勘,用戶點擊了同意還是不同意箱靴,以及用戶之后又做了怎樣的更改我們都無從得知,現(xiàn)在 apple 開放了這個 API荷愕,我們可以直接獲取到用戶的設(shè)定信息了衡怀。注意UNNotificationSettings是只讀對象哦,不能直接修改安疗!
[center getNotificationSettingsWithCompletionHandler:^(UNNotificationSettings * _Nonnull settings) {
NSLog(@"通知配置信息:\n%@",settings);
}];
//注冊通知獲取token
[application registerForRemoteNotifications];
}
三抛杨、接收到自定義的通知時實現(xiàn)自定義操作
其實第3步又分為2小步,通過上圖可以看到事件注冊是先把按鈕操作對象放到分類對象中荐类,然后將分類對象給通知中心蝶桶。同理,在接收到推送通知時掉冶,需要逆向走一遍邏輯真竖,即先根據(jù)分類ID判斷是哪個分類,然后根據(jù)按鈕ID判斷是分類中的哪個按鈕厌小。
//app通知的點擊事件
//只會是用戶點擊消息才會觸發(fā)恢共,如果使用戶長按(3DTouch)、Action等并不會觸發(fā)
-(void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler{
//收到推送的請求
UNNotificationRequest *request = response.notification.request;
//收到的內(nèi)容
UNNotificationContent *content = request.content;
//收到用戶的基本信息
NSDictionary *userInfo = content.userInfo;
//收到消息的角標(biāo)
NSNumber *badge = content.badge;
//收到消息的body
NSString *body = content.body;
//收到消息的聲音
UNNotificationSound *sound = content.sound;
//推送消息的副標(biāo)題
NSString *subtitle = content.subtitle;
//推送消息的標(biāo)題
NSString *title = content.title;
if ([response.notification.request.trigger isKindOfClass:[UNNotificationTrigger class]]) {
NSLog(@"點擊了通知:%@\n",userInfo);
}
else{
NSLog(@"通知:{\nbody:%@璧亚,\ntitle:%@,\nsubtitle:%@,\nbadge:%@讨韭,\nsound:%@,\nuserInfo:%@}",body,title,subtitle,badge,sound,userInfo);
}
//處理消息的事件
NSString *category = content.categoryIdentifier;
if ([category isEqualToString:@"reply"]) {
[self handCommnet:response];
}
completionHandler();
}
-(void)handCommnet:(UNNotificationResponse *)response{
NSString *actionType = response.actionIdentifier;
NSString *textStr = @"";
if ([actionType isEqualToString:@"inputClick"]) {
UNTextInputNotificationResponse *temp = (UNTextInputNotificationResponse *)response;
textStr = temp.userText;
}
NSLog(@"回復(fù)的內(nèi)容是:%@",textStr);
}
手機端在不鎖屏?xí)r癣蟋,下拉可以回復(fù)透硝,鎖屏?xí)r不行。手表在鎖屏?xí)r疯搅,收到通知會自動喚醒解鎖界面濒生,解開后也不會收通知(通知中心沒有推送信息)。
GitHub給個星哈幔欧!Demo地址