近日,好多支付语音播报App都遇到一个问题原来好好的语音播报在iOS12.1上无效了,这可急哭了一群小伙伴,原因是在NotificationService新特性里面爸爸禁用了audio session,下面是官方声明
为了解决这个问题,楼主也是想了几种方案:
第一种方案:既然播报不了那是不是可以使用内置语音包,通过推送不同的sound字段来控制播报,答案肯定是可以的,不过这样有一个弊端会导致IPA包会比较大,至于语音文件可以使用科大讯飞或是百度语音合成来生成,楼主使用的Python生成的语音包;
使用脚本生成了10000个语音文件,但是这时候却发现10000音频文件竟然有450M,那这肯定是接受不了的,所以只能将m4a转成码率较小的MP3格式。这时需要用到FFmpeg,所以你需要先搭建环境,需要搭建环境的请戳这里。接下来进行格式转换了
转换之后发现语音包大小下降了2/3,ok这就能接受了,当然有更好的压缩方案的小伙伴可以联系楼主,好了,多的也不用讲,那我们语音播报一般都有个前缀语音提示,这就需要我们合并一下音频了,当然没这个需求的小伙伴可以忽略
最终的文件如下
到这里第一种方案就竣工了,接下来只要后台根据支付方式以及支付金额推送不同的sound字段即可
第二种方案:思路也是来源于sound字段,使用语音包还是有一个弊端就是IPA太大,这时萌生了一个想法,能不能动态拼接呢?这可把楼主一顿想,这时发现一种方案在拓展里面接受到推送后通过发送本地通知来实现呢?答案是可以的,多的也不讲上代码
首先将我们准备好的语音文件主工程,然后设置对应的播放时间(根据音频文件来定)
这里需要注意的是我们不需要本地推送有弹窗,所以title和body都设置为空,或者注册通知的时候不启用UNAuthorizationOptionAlert,还要注意的是拓展里面需要设置一下本地化。
这样方案二就算是完成了,但这里有一个弊端就是无法消除震动,只能让用户设置关闭震动,优势就是能有效降低IPA包的大小
方案三:使用VOIP唤醒App
VOIP全称voice-over-ip,是iOS8新引入的一种推送方式类型。它可以使用户收到一个来电时唤醒App。有了这种新推送,麻麻再也不用担心App长时间在后台被系统杀死的问题了,因为这种推送消息可以在后台唤醒App。
具体VOIP的实现这里就不做详细的阐述,VOIP是苹果针对即时通讯类应用开启的,但并不只有纯聊天类应用才能通过审核,微信自然是不用说了,肯定是使用的VOIP,支付宝在iOS 12.1来临之前其实也是使用的语音合成,后面初期解决12.1播报问题也是使用的语音包,楼主亲测如此,就在前天支付宝已经完成了iOS12.1语音精准播报,然后包的大小并没有太多变化,因此楼主基本肯定是使用了VOIP来唤醒App从而达到语音在线合成播报的目的,所以说只要你能提供给爸爸语音/视频呼入呼出的录制视频,基本也是能通过审核大关的。当然VOIP方案虽然是可行,但实现成本过高,前后端的变动都比较大,服务端得搭建一套自己的推送,不再依赖第三方推送平台。
以上是楼主目前能解决iOS12.1播报问题的三种方案,综合体验和准确度来说的话,个人还是偏向第一种方案,各位小伙伴根据公司自身产品可自行选择,最后感谢各位的阅读,如有不足之处或有更好的实现方案请联系QQ:895431603