iOS,推送+后台语音播报,推送+程序杀死仍语音播报,看这一篇就够啦!

96
CoderRocker_Axl
1.0 2017.09.04 14:24* 字数 1682

第一篇文章,如果有写的不正确的、或者让人看不懂的地方,还希望大家能指正出来,共同进步,好了下面开始正题。

哇,好久不写文章真的不知道从何说起了。

一个多月前公司app改版,产品希望能加入语音播报的功能。在我们用户收到推送的时候,动态的播报出语音的内容,类似支付宝的“成功收款100元”这样的信息。由于时间紧迫当时也是在网上搜了很多的方法,参考了很多大神的文章。
http://www.jianshu.com/p/c06133d576e4

这一篇是对我帮助很大的一篇文章,当时就是按照文中的方法对推送进行了处理,可以在app前台、后台挂起的情况下进行语音播报。瑕疵就是在app被杀死的情况下无法播报。有时在后台,当用户打开qq音乐后,也不能播报(这可能是我写的问题,不能在音频被独占后再次播放)。而且审核有可能被拒绝。
我们改版后第一次提交审核并没有被拒绝,当时还是很开心的,因为如果因为后台播放音频被拒,还得录视频,还得再次审核,这个时间成本真的是耽误不起。
之后的第二版就悲剧了,果断因为这个被拒绝,我发了邮件解释了我们的用法,但是还是被拒绝了。同时我们产品也对语音播报的不稳定提出了很大的意见:支付宝程序杀死都能播报,为什么我们不能?还有那么多情况播不了??你还能不能行了,是不是想被祭天!?

当时我内心是崩溃的

但同时也激起了我的好奇心,为什么程序杀死的情况下也能对推送进行处理?这是我以前没接触过的。不过我相信,别人能做出来的,我一定也能做出来!于是马上投入了研究,最后终于找出了比较完美的办法来实现这样的功能。下面让我们进入正题吧!

需求分析

一、语音合成

语音合成是这个功能比较简单的部分,苹果已经提供了一个功能强大的语音类AVSpeechSynthesis。如果你对于声音没有什么特殊要求,AVSpeechSynthesis 是一个很好的工具。在此就不在对AVSpeechSynthesis 做赘述了。下面是一个写的比较完整的文章,大家可以参考一下。
http://www.jianshu.com/p/a41cb018f0b5

二、远程推送

这是本次功能的难点,在前台收到推送并根据内容用AVSpeechSynthesis去合成语音是一个很简单的功能,但是如何在程序进入后台、程序杀死的情况下执行代码,这是我们要研究的一个问题。在网上搜了很多的资料后,终于找到了解决这个问题的主角 ------ Notification Service Extension,通知服务扩展。

三、Notification Service Extension 通知服务扩展

这是iOS 10.0推出的新功能。
https://developer.apple.com/documentation/usernotifications/unnotificationserviceextension
上面是官方文档的连接,按我的理解总结下来一句话,就是他能让你在收到远程推送的时候先对推送内容进行预处理,处理完之后,再让你的app进行处理。而且这部分代码是和你本身app隔离开的(这个在接下来的代码环节会有个直观的认识),这样就给了我们单独处理相应推送的地方。下面就让我们具体的看一下怎么操作。

简单实现

一、为项目添加Notification Service Extension

首先打开你的项目 File ----> New ------> Target

屏幕快照 2017-09-04 下午1.22.39.png

选择Notification Service Extension

屏幕快照 2017-09-04 下午1.23.09.png

进行命名。这里Bundle identifier之类的内容,xcode会自动为你配置好,所以不用担心。其实从这里可以看出来,这个target并不属于你的app里面的一部分,而是另一个全新的程序,但是他是和你的app绑定的,这样,当推送来的时候iphone就知道究竟是谁的推送过来,需不需要进行额外处理。

屏幕快照 2017-09-04 下午1.24.13.png

Finish之后,你就可以在你的工程里看到你app的Notification Service Extension了。需要注意的是,因为是两个完全独立的target所以,你原有项目里的自己写的类,或原有项目里的资源文件,在Notification Service Extension里是完全访问不到的(打包之后也是两个完全独立的bundle)。所以如果你想要使用项目里的资源或者文件,你需要拖到Notification Service Extension目录里面,才可以使用。

屏幕快照 2017-09-04 下午1.51.04.png

二、对推送内容进行预处理

接下来就是业务代码了,在生成的NotificationService.m文件里对推送来的payload进行处理,在这里,你可以进行一些操作,例如修改推送的内容。要注意的是,并不是所有的推送都会走这个额外的方法。必须是会弹出alert、并且payload里面要设置"mutable-content"字段的值为1,才会进入这个方法,这都是需要跟你们后台沟通的。
{
"aps": {
"alert": "This is some fancy message.",
"badge": 1,
"sound": "default",
"mutable-content": "1",
}
}

屏幕快照 2017-09-04 下午1.26.32.png

在我们拿到需要播报的字段后,用AVSpeechSynthesis进行播放就可以啦。而且在处理之后,你的app是仍然可以收到该推送,而且得到的数据是你在NotificationService.m里修改过的数据(如果你修改了的话)。所以注意不要处理两遍哦。

屏幕快照 2017-09-04 下午2.12.22.png

调试的时候需要注意一点,如果你想走NotificationService.m里面的断点,需要将你Scheme调成对应的target

屏幕快照 2017-09-04 下午1.51.19.png

好啦,整个功能的简单实现到这里就结束啦,注意这个方法只有在10.0以后才可以用哦。
Notification Service Extension还有很多很强大的功能,大家可以继续发掘。
有什么建议或者疑问都可以留言,大家共同进步哇~~

日记本
Web note ad 1