从大四实习开始从事Android开发至今已有数年时间,开发中遇到过不少坑,下面跟大家分享下。
进程保活
这个相信开发过Android的同学都不陌生,关于这方面的内容,大家可以参考以下两篇文章:
然而根据我的实践,上述的方法似乎都不能很好的解决这个问题。微信、QQ这些APP之所有能在几乎所有手机上保持后台运行,是因为厂商对他们做了特殊处理,即所谓的白名单。我们没有相应的资源,这条路自然也是行不通的。
所以只能根据自身的实际需求进行妥协处理,比如我们之前的需求是要保持订单能及时通知到APP。我们一开始用的方案是通过mqtt进行IM通信(mqtt是一种比较轻量级的基于发布/订阅范式的消息协议,可以用于IM和通知等场景),正常情况下是可以及时下发订单的。但是如果APP在后台长时间运行的话,有很大可能进程会被杀掉,即使没被杀,也会因为doze机制(Android 6.0添加的待机模式)或其他类似机制导致网络被限制。所以我们改变了策略,在保留mqtt通道的情况下,新增第三方推送通道。考虑到实际效果,我们最后决定如果厂商有自有的推送通道则优先使用厂商的推送(华为、小米,魅族的推送好像已经关闭了),没有的话就用腾讯的信鸽推送。实际上在接入腾讯信鸽sdk的同时,它集成了对华为、小米等通道,所以集成起来还是挺方便的。这样通过双通道来保证订单能及时推送,效果还是挺不过的,如果有类似的场景,建议也这么处理下。
闭屏时显示弹框/弹出界面
有这么一个场景,在收到某个指令之后,需要弹窗或者弹界面来通知用户或者让用户操作。这个实现起来很简单,就是起个dialog或者start一个activity。不过如果此时用户刚好锁屏了,在很多手机上是行不通的,因为很多国产手机上有闭屏弹窗和显示悬浮窗的权限。
对于这种情况,我们的处理方式是在收到指令的时候,如果用户此时没有锁屏,那就播放声音且直接弹窗,如果此时是锁屏状态,那就先点亮屏幕并播放声音提醒用户,待用户解锁后再弹出界面(这里点亮屏幕等操作有打扰用户的嫌疑,还有解锁弹界面的时效等,这些关乎具体的场景)。这里的思想是对于一些比较重要的场景,能避开的权限那就尽量避开,如果实在避不开,那就需要考虑是否要强制用户授权了,当然这个相当不友好,轻易不要这么做。
关于notification
也许是出于对用户的保护,Android上的notification限制比较多。另外坑也比较多,要考虑到兼容性。比如可扩展的样式(bigText/bigPicture等)是在4.1及以上才支持的,再比如在8.0之后添加了NotificationChannel这个概念,没有兼容的话会显示不出来。另外系统对通知的高度也是有限制的,在普通的样式下,高度是不大于64dp,展开时不大于256dp,所以在开发中要特别注意,特别是自定义layout的情况下。
另外对于同样的处理逻辑,在不同的手机上的表现是不尽相同的,这点是大坑。比如使用大图样式(bigPicture),在谷歌亲儿子上,如果当前的通知在首位,是会自动显示展开的布局的,但是在三星的手机上是默认显示折叠的样式的。所以对于产品提的这方面的需求,大家要先想好能不能实现。
待续。。