iWatch同步接收连接手机的通知,查看起来非常方便。像微信这种及时通讯消息的通知还有快捷回复,更方便。接下来就说说如何实现在iWatch的通知中心实现信息的快捷回复。
要实现这一功能需要iOS10以上系统,因为用到了UserNotifications framework
这个框架。UserNotifications framework
让开发者可以更多样的实现通知界面。详细使用可查看这篇文章。
实现这一功能主要有3步:
1>注册自定义通知操作类型
2>请求本地和远程通知的交互操作授权
3>接收到自定义的通知时实现自定义操作
一、注册自定义通知操作类型
在程序入口方法- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
中注册自定义操作。为了代码整洁这部分功能做了封装,封装为一个NotificationHandle
类。
在NotificationHandle
类 的registerNotificationCategory
方法中做了注册自定义操作,代码如下。
//注册通知中的action事件
-(void)registerNotificationCategory{
//带回复的通知事件注册
UNTextInputNotificationAction *replyAction = [UNTextInputNotificationAction actionWithIdentifier:@"replyClick" title:@"回复" options:UNNotificationActionOptionAuthenticationRequired textInputButtonTitle:@"发送" textInputPlaceholder:@"请输入评论内容.."];
UNNotificationCategory *tapCategory = [UNNotificationCategory categoryWithIdentifier:@"reply" actions:@[replyAction] intentIdentifiers:@[] options:UNNotificationCategoryOptionCustomDismissAction];
NSSet *set = [[NSSet alloc]initWithObjects:tapCategory, nil];
[[UNUserNotificationCenter currentNotificationCenter] setNotificationCategories:set];
}
二、请求本地和远程通知的交互操作授权
-(void)authorizationPushNotificaton:(UIApplication *)application{
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
center.delegate = self; //必须写代理
[center requestAuthorizationWithOptions:UNAuthorizationOptionBadge | UNAuthorizationOptionSound | UNAuthorizationOptionAlert | UNAuthorizationOptionCarPlay completionHandler:^(BOOL granted, NSError * _Nullable error) {
//注册之后的回调
if (!error && granted) {
NSLog(@"注册成功...");
}
else{
NSLog(@"注册失败...");
}
}];
//获取注册之后的权限设置
//之前注册推送服务,用户点击了同意还是不同意,以及用户之后又做了怎样的更改我们都无从得知,现在 apple 开放了这个 API,我们可以直接获取到用户的设定信息了。注意UNNotificationSettings是只读对象哦,不能直接修改!
[center getNotificationSettingsWithCompletionHandler:^(UNNotificationSettings * _Nonnull settings) {
NSLog(@"通知配置信息:\n%@",settings);
}];
//注册通知获取token
[application registerForRemoteNotifications];
}
三、接收到自定义的通知时实现自定义操作
其实第3步又分为2小步,通过上图可以看到事件注册是先把按钮操作对象放到分类对象中,然后将分类对象给通知中心。同理,在接收到推送通知时,需要逆向走一遍逻辑,即先根据分类ID判断是哪个分类,然后根据按钮ID判断是分类中的哪个按钮。
//app通知的点击事件
//只会是用户点击消息才会触发,如果使用户长按(3DTouch)、Action等并不会触发
-(void)userNotificationCenter:(UNUserNotificationCenter *)center didReceiveNotificationResponse:(UNNotificationResponse *)response withCompletionHandler:(void (^)())completionHandler{
//收到推送的请求
UNNotificationRequest *request = response.notification.request;
//收到的内容
UNNotificationContent *content = request.content;
//收到用户的基本信息
NSDictionary *userInfo = content.userInfo;
//收到消息的角标
NSNumber *badge = content.badge;
//收到消息的body
NSString *body = content.body;
//收到消息的声音
UNNotificationSound *sound = content.sound;
//推送消息的副标题
NSString *subtitle = content.subtitle;
//推送消息的标题
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(@"回复的内容是:%@",textStr);
}
手机端在不锁屏时,下拉可以回复,锁屏时不行。手表在锁屏时,收到通知会自动唤醒解锁界面,解开后也不会收通知(通知中心没有推送信息)。
GitHub给个星哈!Demo地址