IOS10以后的通知实战(删除,合并通知,自定义通知界面不在困难)

花絮
苏州经历了10多天的40℃+的高温。半个多月的35℃+的天气,今天终于下雨了,下雨天,睡觉天。炎热的天气,使烦躁的心情,让学习的动力一天天在减少。对于代码的兴趣也在慢慢减退,对待学习这件事也是一推再推,工作也正式由PHP转行成了iOS(也许只有这几天),刚好把学到的通知新特性总结一下:(Demo使用的是swift写法) Demo

主要内容包含:

  • iOS10以后的通知详解资料地址(基础的资料网上很多,本人就不一一写了)
  • 通知实战的演练gif动画效果
  • 实现通知的自己的总结,以及通知类之间的关联(本人觉得这部分很重要)
  • 项目和traget之间数据的共用
  • 多个target之间和项目之间使用pod

iOS10 通知的基础资料地址

解释两个基本扩展(Notification ContentNotification Service

  • 很多人都认为Notification Content是为了处理本地通知的,其实不是的,Notification Content其实是用来自定义长按通知显示通知的自定义界面,
  • Notification Service是用来处理远程通知的,我们可以在远程通知到来之际,我们在Notification Service里面由30s的时间来处理这条通知的
创建target第一步
通知相关的target
创建完成界面

注意:content调用,必须在info里面设置,通知的category的indetifier

category的indetifier

注意:service调用,在通知的内容里面设置``mutable-content:1`注意必须是数字1,如果是"1"字符串也是不行的

以上两个注意非常重要,重要的事情说三遍
以上两个注意非常重要,重要的事情说三遍
以上两个注意非常重要,重要的事情说三遍

通知实战的演练gif动画效果

  • 显示Action按钮


    显示Action按钮
  • 显示回复输入框


    显示回复输入框
  • 携带图片的通知且可以添加Action


    携带图片的通知且可以添加Action
  • 携带图片的通知且调用的是自定义界面


    携带图片的通知且调用的是自定义界面
  • 携带gif的通知且调用的是自定义界面


    携带gif的通知且调用的是自定义界面
  • 调用自定义界面,并且可以在app启动前处理按钮(*注意:只用在App在使用自定义界面(也就是使用Notification content扩展)的时候,我们才可以预先处理按钮点击

    调用自定义界面,并且可以在app启动前处理按钮

  • 显示一下通知在后台的删除功能

    删除通知

    同样我们也是可以根据远程通知在Notification Service里面进行通知的删除,更新,或者查看没有到达用户手机的通知,从而进行你需要的操作

image.png
  func localImage()->URL?{

    let count = Int(arc4random_uniform(4));
    let imageName = imagas[count];
    let url = Bundle.main.url(forResource: imageName, withExtension: nil);
    return url;
}
func saveServiceImageToDic(_ stringUrl:String) -> URL? {
    let path = "image.png".wj_getCachesPath();
    let url = URL.init(fileURLWithPath: path);
    let data =  try? Data.init(contentsOf: URL.init(string: stringUrl)!);
    guard data != nil else {
        return nil;
    }
    try? data?.write(to: url);
   
    return url;
}

3.实现通知的自己的总结,以及通知类之间的关联(本人觉得这部分很重要)重要

    1.UNUserNotificationCenter 是通知的管理大脑,我们要把通知的触请求到UNUserNotificationCenter里面,UNUserNotificationCenter会根据通知请求(UNNotificationRequest)里面的通知本身(UNNotificationContent)里面的设置来响应设置的通知
    2.UNNotificationRequest  是通知请求,我们是把通知的触发器和通知本身来创建一个通知请求,并可以直接添加到通知中心里面。我们可以在通知中心根据不同的indentifier来区分请求,其实一个请求就是一个通知
    3.UNNotificationTrigger     通知触发器,抽象类,一般使用子类UNPushNotificationTrigger(远程通知)、UNTimeIntervalNotificationTrigger(间隔触发器)、UNCalendarNotificationTrigger(日历触发器)、UNLocationNotificationTrigger(地区触发器),其中间隔触发器、日历触发器、地区触发器都是本地通知
    4.UNNotificationContent     通知内容本身,我们可以设置通知的title。body、useinfo、sound、brage等属性来。但是它是只读对象,我们一般使用它的子类UNMutableNotificationContent来设置。当然我们也是可以设置通知本身的category或者Attachment
    5.UNNotificationCategory    通知的分类,我们可以根据通知分类的indenterfiter来使用Notification Content扩展来自定义展示通知内容
    6.UNNotificationAction      通知按钮,我们可以将创建的category来制定action(也就是按钮),当我们点击按钮的时候,我们可以在appdelegate里面func userNotificationCenter(_ center: UNUserNotificationCenter, didReceive response: UNNotificationResponse, withCompletionHandler completionHandler: @escaping () -> Void) 来获取点击的按钮,特别是回复按钮比较使用
    7.UNNotificationAttachment  通知的附件,附件可以携带,音频5M  图像10M支持  jepg,png。git   视频50M,注意:如果是网络信息,这些附件必须是https连接,并且notification servicer只由30秒的下载时间

以下是附加部分

4.项目和traget之间数据的共用

个人理解:其实项目和trager资源是可以公用的,一般默认情况下,资源是分开的,只要我们给target添加上就就可以使用了。

image.png

5.多个target之间和项目之间使用pod

image.png

最后奉上。自己写的 Demo,如有不对,请大家留言,七秒及时更正

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容