iOS 玩转推送通知

转自:http://www.cocoachina.com/ios/20160316/15665.html

前言

推送通知,想必大家都很熟悉,关于原理之类的,这里就不过多阐述。在这里我们主要介绍下iOS8及iOS9之后关于推送的新功能。大家可能见过听说过,但可能有一些朋友并没有上手做过。这篇文章便给大家详细介绍推送中的快捷按钮及快捷回复等功能的实现。

快捷点赞,如微博点赞功能

效果图大家可以先看下:

首先先说如何为自己的推送添加快捷功能,该Demo中的动作 “赞”,代码如下:

//创建消息上面要添加的动作
    UIMutableUserNotificationAction *action1 = [[UIMutableUserNotificationAction alloc] init];
    action1.identifier = kNotificationActionIdentifileStar;
    action1.title = @"赞";
    //当点击的时候不启动程序,在后台处理
    action1.activationMode = UIUserNotificationActivationModeBackground;
    //需要解锁才能处理(意思就是如果在锁屏界面收到通知,并且iPhone设置了屏幕锁,点击了赞不会直接进入我们的回调进行处理,而是需要输入屏幕锁密码之后才进入我们的回调),如果action.activationMode = UIUserNotificationActivationModeForeground;则这个属性被忽略;
    action1.authenticationRequired = YES;
    /*
     destructive属性设置后,在通知栏或锁屏界面左划,按钮颜色会变为红色
     如果两个按钮均设置为YES,则均为红色(略难看)
     如果两个按钮均设置为NO,即默认值,则第一个为蓝色,第二个为浅灰色
     如果一个YES一个NO,则都显示对应的颜色,即红蓝双色 (CP色)。
     */
    action1.destructive = NO;

关于参数的意思,上方代码中已经有详细的解释了,那么该动作按钮创建完之后,我们需要的就是创建动作集合,并进行注册,代码如下:

//创建动作(按钮)的类别集合
    UIMutableUserNotificationCategory *category = [[UIMutableUserNotificationCategory alloc] init];
    //这组动作的唯一标示(kNotificationCategoryIdentifile为我定义的一个宏,可自行定义)
    category.identifier = kNotificationCategoryIdentifile;
    //最多支持两个,如果添加更多的话,后面的将被忽略
    [category setActions:@[action1, action2] forContext:(UIUserNotificationActionContextMinimal)];
    //创建UIUserNotificationSettings,并设置消息的显示类类型
    UIUserNotificationSettings *uns = [UIUserNotificationSettings settingsForTypes:(UIUserNotificationTypeAlert|UIUserNotificationTypeBadge|UIUserNotificationTypeSound) categories:[NSSet setWithObject:category]];
    [[UIApplication sharedApplication] registerUserNotificationSettings:uns];

到这里便能实现推送中快捷点赞的功能了。当然我们还会注意到iPhone中短信有快捷回复功能,这个是怎么实现的呢。 客官请往下继续看。

快捷回复,如短信中下拉快捷回复功能

老规矩,还是先上效果图,如下:

这个评论的动作和上面的“赞“只是多了一个属性的设置,即”behavior“。代码如下:

//第二个动作
    UIMutableUserNotificationAction *action2 = [[UIMutableUserNotificationAction alloc] init];
    action2.identifier = kNotificationActionIdentifileComment;
    action2.title = @"评论";
    //当点击的时候不启动程序,在后台处理
    action2.activationMode = UIUserNotificationActivationModeBackground;
    //设置了behavior属性为 UIUserNotificationActionBehaviorTextInput 的话,则点击了该按钮会出现输入框供输入
    action2.behavior = UIUserNotificationActionBehaviorTextInput;

细心的朋友可能注意到我在快捷回复输入内容时候,输入框右边的按钮名字和短信的快捷回复按钮名字并不一样(短信的为”发送“,该Demo为”评论“),这个按钮我们也是可以进行自定义的,代码如下:

//这个字典定义了当点击了评论按钮后,输入框右侧的按钮名称,如果不设置该字典,则右侧按钮名称默认为 “发送”
    action2.parameters = @{UIUserNotificationTextInputActionButtonTitleKey: @"评论"};

到这里,该Demo的基本功能就已经差不多完全实现了。剩下的就是回调了,回调走的函数便是AppDelegate中的代理方法了,如下:

// 本地通知回调函数,当应用程序在前台时调用
- (void)application:(UIApplication *)application didReceiveLocalNotification:(UILocalNotification *)notification;
//在非本App界面时收到本地消息,下拉消息会有快捷回复的按钮,点击按钮后调用的方法,根据identifier来判断点击的哪个按钮,notification为消息内容
- (void)application:(UIApplication *)application handleActionWithIdentifier:(nullable NSString *)identifier forLocalNotification:(UILocalNotification *)notification withResponseInfo:(NSDictionary *)responseInfo completionHandler:(void(^)())completionHandler;

结束语

1:以上代码是只注册了本地推送的,远程推送和本地推送类似,推送消息如果要触发快捷动作,则需要在消息本体中含有上面category的identifier标志。如

//这个"Identifile"的需要和你在代码中设置的kNotificationCategoryIdentifile保持一致
{"aps":{"Identifile":"test remote notification", "sound":"default", "badge": 1, "category":"category"}}

2:在码代码时候如果需要兼容低版本的话,请注意在代码中进行版本的判断。

3:最后奉上Demo地址。

时间: 2024-10-16 22:45:04

iOS 玩转推送通知的相关文章

iOS开发 - ANPs推送通知 标签: 推送通知ANPs远程推送、本地推送

iOS开发 - ANPs推送通知 标签: 推送通知ANPs远程推送本地推送 2015-05-03 14:12 3510人阅读 评论(0) 收藏 举报 本文章已收录于:  iOS知识库  分类: [IOS -事件响应者链](3)  版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 推送通知 注意:这里说的推送通知跟NSNotification有所区别 NSNotification是抽象的,不可见的 推送通知是可见的(能用肉眼看到) iOS中提供了2种推送通知 本地推送通知(L

iOS上简单推送通知(Push Notification)的实现

http://blog.csdn.net/daydreamingboy/article/details/7977098 iOS上简单推送通知(Push Notification)的实现 根据这篇很好的教程(http://www.raywenderlich.com/3443/apple-push-notification-services-tutorial-part-12),结合自己的实践,写下一点笔记,仅供参考:) 由于篇幅较长,我列出简单的目录,如下 1) 理解Apple推送通知的机制 2)

iOS开发 - ANPs推送通知

推送通知 注意:这里说的推送通知跟NSNotification有所区别 NSNotification是抽象的,不可见的 推送通知是可见的(能用肉眼看到) iOS中提供了2种推送通知 本地推送通知(Local Notification) 远程推送通知(Remote Notification) 推送通知的呈现效果总结 总结一下,推送通知有5种不同的呈现效果 在屏幕顶部显示一块横幅(显示具体内容) 在屏幕中间弹出一个UIAlertView(显示具体内容) 在锁屏界面显示一块横幅(锁屏状态下,显示具体内

苹果iOS APNS消息推送通知

参考链接: http://www.tairan.com/archives/194 http://www.tairan.com/archives/240 https://developer.apple.com/library/ios/documentation/NetworkingInternet/Conceptual/RemoteNotificationsPG/Chapters/ProvisioningDevelopment.html#//apple_ref/doc/uid/TP40008194

ios如何实现推送通知

推送通知的步骤:1.询问是否允许推送通知.2.如果用户允许在APPDELEGATE 中实现 - (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData*)deviceToken{ } 3.将token发送到服务器上 4.服务器收到toke后 发送推送通知,客户端相应该推送同通知 代码如下: [cpp] view plaincopy //每次唤醒

iOS开发中通知(Notification)快速入门及推送通知实现教程

iOS开发中通知(Notification)快速入门及推送通知实现教程 标签: NSNotificationCenterNSNotification 2016-11-14 00:18 232人阅读 评论(0) 收藏 举报  分类: iOS(400)  转载自:http://www.111cn.NET/sj/ios8/90190.htm 通知(Notification)是开发框架中观察者模式的一种实现方式,内部的实现机制由Cocoa框架支持,通常用于试图控制器和数据模型的交互.通过通知,可以向一个

IOS推送通知测试工具PushMeBaby

下载了PushMeBaby在xcode5里中不能使用,类库变了.需要添加Carbon.framework库,在引用的地方改成: #include <Carbon/Carbon.h>,程序就可以 运行了.测试时要变成自己的证书. 下载地址:点击打开链接 IOS推送通知测试工具PushMeBaby,码迷,mamicode.com

iOS 推送通知流程

别的不说,现在AppDelegate.m中添加以下代码块 - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {     // 将这行代码插入     [[UIApplication sharedApplication] registerForRemoteNotificationTypes:UIRemoteNotificationT

(七十三)iOS本地推送通知的实现

iOS的推送通知分为本地推送和网络推送两种,如果App处于挂起状态,是可以发送本地通知的,如果已经被杀掉,则只有定时通知可以被执行,而类似于QQ的那种网络消息推送就无法实现了,因为App的网络模块在被杀掉后是无法执行的,这时候就要借助远程通知,通过苹果的服务器转发通知到手机,本文只介绍本地通知的用法. ①对于iOS8及以上的版本,需要注册本地通知才能使用,一般在AppDelegate中注册: if ([[UIDevice currentDevice].systemVersion doubleVa