前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >Android-Q 对 startActivity() 做了限制,怎么适配?

Android-Q 对 startActivity() 做了限制,怎么适配?

原创
作者头像
CCCruch
修改于 2019-07-08 03:01:09
修改于 2019-07-08 03:01:09
3.8K0
举报

一. Q 禁用后台启动 Activity

当时由于主题所限,没有聊到技术细节。今天就延续这个话题,再聊聊 Android Q 限制后台启动 Activity 的具体细节。

有人可能会觉得 P 还没用上,Q 还远着。如果只是对于普通用户来说,确实是这样,大多数情况新系统对应的就是新设备,手机的换代速度是远低于系统升级的。但是对于我们开发者来说,老旧的系统版本可以战略性的放弃,但是新系统肯定要率先支持的。

就算你不想这么做,各大硬件厂商,也会推动你去做,毕竟最新的设备都是搭载的最新的系统,App 不稳定,肯定是影响用户体验的。

Android Q 在今年 Q3 季度,就准备发布正式版了,了解 Android Q 的新特性,也是我们开发者马上马就要面临的事情了。

言归正传,继续聊 Android Q 下,禁止后台启动 Activity。

二. 限制影响的范围

以最新的 Android Q Beta 4 来举例,当你的 App 处于后台时,一旦尝试开启新的页面,会发生什么呢?首先你的新页面肯定是打不开的,在现有的 Beta 版本上,系统还会输出一条警告 Log,并弹出一条 Toast。

例如,我们开发者比较常用的 掘金App。

官方文档表示,Toast 提醒会在 Android Q 的正式版中去掉。同时这里的没打开是真的没打开,它并不会压入到 Activity 的回退栈中。

Android Q 中针对启动 Activity 的限制,更多的也是为了增加用户体验和安全性。多数时候,我们开启新页面的动作,都来自用户操作,但是依然存在一些 App,在后台活着,监听用户的一些事件,在他们觉得必要的时机,弹出来骚扰用户。

比较常见的场景,你正在拍摄某个重要的瞬间,此时突然从后台弹出一个广告,精彩瞬间肯定是错过了,这必然会影响用户体验。

再比如一些工具类 App,会在某些事件上对你做出提醒,例如某浏览器就监听了卸载 App 的事件,在我卸载 App 后,提醒是否需要清理手机内存。

这些其实都是工具类 App 功能上的扩展,在 Android Q 下,这将是不被允许的。

在曾经那么多 Android 版本的适配中,很多新系统的特性,其实是有兼容模式的,只要保持 App 的 targetVersion 不升级,就不会触发新系统特性。

但是这一点,在 Android Q 的禁止后台启动页面这一项上,是不起作用的。此项变动适用于所有在 Android Q 上运行的应用,哪怕你没有升级 targetVersion,哪怕你是在 Android P(9)中安装应用,系统从就版本升级到 Android Q,此项改动都会生效。

只要跑在 Android Q 上的 App,均受限制。

原则上,只要你的 App 在前台,或者此次启动新页面的动作来自用户主动的操作,那自然是不受影响的。

1. 该应用具有可见窗口。例如前台 Activity 是你的应用。

2. 桌面 Widget 点击启动 Activity。

3. 当前前台任务的 Activity Back Task(回退栈)中,有你应用的 Activity。

例如调起微信支付页(Activity Z)时,当前退回栈最顶端的 Activity 其实时微信的页面,但是我们应用页面(Activity Y)依然在回退栈的下面,此时依然具有打开 Activity 的权限。

4. 绑定了某些系统服务,例如:AccessibilityService、AutofillService 等。

5. 已获得用户授权的 SYSTEM_ALERT_WINDOW 权限。

6. 临时白名单机制,不拦截通过通知拉起的应用。

  • 应用通过通知,在 pendingIntent 中启动 Activity。
  • 应用通过通知,在 PendingIntent 中发送广播,接收广播后启动 Activity。
  • 应用通过通知,在 PendingIntent 中启动 Service,在 Service 中启动 Activity。

还有一些比较特殊的场景,就不在这里一一举例了,有兴趣可以翻阅文档。

现在允许的这些条件,在 Android Q 正式版发布时,可能还有调整。例如拥有SYSTEM_ALERT_WINDOW 权限可以在后台打开新页这一条,在最初的 Beta1 版本中,是不存在的。

最终肯定是以 Android Q 正式版为准,我们只需要记住,原则上,只要是用户主动的操作或者用户赋予了相应的权限之外,其他情况均会受到影响。

三. 谷歌的适配建议

Android Q 禁用后台启动新页,不是目的,根本问题是为了加强用户体验。在某些场景下,我们也确实有在后台时,弹出新页的需求。

例如:收到微信语音通话时,对用户的强提醒。

总是有一些正当的需求,谷歌也不能直接把路都堵死了。

谷歌的建议是,在后台时,可以通过创建通知的方式,向用户提供信息。由用户通过点击通知的方式,来启动 Activity,而不是直接启动。

如果有必要,还可以通过 setFullScreenIntent() 来强调这是一个立即需要处理的通知。

代码语言:txt
AI代码解释
复制
val fullScreenIntent = Intent(this, BackgroundActivity::class.java)
val fullScreenPendingIntent = PendingIntent.getActivity(
  this, 0,
  fullScreenIntent, PendingIntent.FLAG_UPDATE_CURRENT
)

val notificationBuilder = NotificationCompat.Builder(this, "channelId")
.setSmallIcon(R.mipmap.ic_launcher_round)
.setContentTitle(getString(R.string.app_name))
.setContentText("启动BackgroundActivity")
.setPriority(NotificationCompat.PRIORITY_HIGH)
.setCategory(NotificationCompat.CATEGORY_CALL)

// Use a full-screen intent only for the highest-priority alerts where you
// have an associated activity that you would like to launch after the user
// interacts with the notification. Also, if your app targets Android Q, you
// need to request the USE_FULL_SCREEN_INTENT permission in order for the
// platform to invoke this notification.
.setFullScreenIntent(fullScreenPendingIntent, true)

val incomingCallNotification = notificationBuilder.build()

// The integer ID that you give to startForeground() must not be 0.
startForeground(1, incomingCallNotification)

此时通知栏就会收到你给的通知,等待用户来处理。

利用通知来提醒用户,其实也有一些优势,例如不会打扰用户当前的行为,锁屏时依然可以提醒用户等等。

利用通知,其实只是我们的应用在后台时的一种替代方案,我们只需要根据不同的场景,在前台时打开新页,在后台时,使用通知提醒。

具体如何判断当前 App 时否在前台,可以利用registerActivityLifecycleCallbacks() 方法,对所有页面的生命周期进行监控,以此为依据来确定具体逻辑。

从 Beta2 开始,此限制是默认开启的,可以通过开发者选项 → 『允许后台活动启动』选项来控制其功能的开启和关闭。

四. 小结时刻

Android Q 下,限制后台启动页面的具体细节就到这里了,简单小结一下。

  1. Android Q 下,开始限制后台应用启动新页面,并且影响所有应用。
  2. 有一些例外场景,原则上为用户触发或者获得用户授权的情况下,依然可以打开新页,这时不受影响的。
  3. 在后台时,依然想为用户提供服务,可以借助通知(Notification)提醒用户。

就这样吧,Android Q 要来了,后续还会更新一些适配改动的细节,有问题可以留言讨论。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Android Q 要来了,一个影响国内 90% App 的适配项!
Android Q 在今年 Q3 就准备发布正式版了,但有一个影响 90% 应用的适配改动。
Android技术干货分享
2019/08/14
1.3K0
Android Q 要来了,一个影响国内 90% App 的适配项!
Android开发高级进阶——Service与Notification
Service是处理一些后台任务,在主线程中,并不能执行耗时操作。而Thread是开启一个子线程,在子线程中执行耗时操作,这样不会阻塞主线程。
trampcr
2018/09/28
1.7K0
全面解析Notification
Notification在Android中使用的频率可以说是非常高的,本篇博客,我将围绕着Notification的各方面进行解析,使大家对Notification有更好的认识。
老马的编程之旅
2022/06/22
2.8K0
全面解析Notification
Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?
Android14 即将正式发布,作为开发者需要注意哪些内容?长话短说,一起来看看吧~
修之竹
2023/11/22
4.7K0
Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?
Android 进阶4:Service 的一些细节
本文介绍了如何在Android开发中使用Service来处理耗时操作,并通过案例演示了如何使用Service与Activity进行交互。同时,还介绍了如何自定义Service,以及如何在Service中弹出Dialog。
张拭心 shixinzhang
2018/01/05
1.2K0
Android 进阶4:Service 的一些细节
【Android 进程保活】应用进程拉活 ( 双进程守护保活 )
双进程守护拉活 , 使用 JobScheduler 拉活 和 系统 Service 机制拉活 两种拉活方式 , 结合起来使用 ;
韩曙亮
2023/03/29
3.5K0
【Android 进程保活】应用进程拉活 ( 双进程守护保活 )
Android 12的行为变更和版本兼容思路
一年一度的产品线兼容活动又开始了。Android系统每更新一次系统,对开发者而言都是持续而漫长的挑战。
aqi00
2022/01/05
4.7K0
Android 12的行为变更和版本兼容思路
Notification与Widget(其实没怎么讲)Android应用界面开发
Notification与Widget,他们为什么要一起讲呢?因为他们很相似,甚至自定义界面的方法都是一样的,这点可能很多书里没有写
爱因斯坦福
2018/09/10
1.4K0
Android6.0到9.0的适配爬坑总结
  大家还记得Android 6.0权限适配的泪水吗?而现在谷歌已经出了Android P的稳定版,而且谷歌粑粑,为了大家能给辛苦熬夜加班,特地的和个大市场合作,要强制推出9.0的适配,而近期在下不才,为了报着多踩坑的心态,做了一下7.0~9.0的适配,脸颊也是老泪两行
用户1269200
2018/12/19
2K0
Android6.0到9.0的适配爬坑总结
App和SDK开发必看 | 个推分享Android12适配指南
10 月 4 日,谷歌将Android12源代码推送至 Android 开源项目 (AOSP)。自从2021年2月发布Android12第一个预览版以来,历经9个月时间测试和优化,正式版本的Android12终于来了!不仅在UI方面做了不少升级,Android12对个人隐私安全的保护也得到了进一步增强。整体来讲,Android12更加智能、高效和安全,感兴趣的开发者可以登录官网下载源码测试学习。
个推君
2021/12/24
1.6K0
App和SDK开发必看 | 个推分享Android12适配指南
Android前台服务的使用(一)
最近由于工作调整,经常会在各地出差的路上,所以原创相对频率可能会慢些,当然空余时间还是会做为学习的输出,今天这篇主要就是介绍了Android的Service组件,Service做为四大组件之一,虽然没有Activity用的多,但是也会使用到,正好最近也是有个想法,先做的Demo技术验证。
Vaccae
2022/09/28
2K0
Android前台服务的使用(一)
在 Android O 上用到 MediaStyle 的提醒功能
原文地址:Migrating MediaStyle notifications to support Android O 原文作者:Nazmul Idris (Naz) 译文出自:掘金翻译计划 本文永
Android 开发者
2018/05/31
2.4K0
Service 使用详解
本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以下内容:
用户1119350
2019/09/16
6920
Android O 后台startService限制简析
Android O 推出出了Background Execution Limits,减少后台应用内存使用及耗电,一个很明显的应用就是不准后台应用通过startService启动服务,这里有两个问题需要弄清楚,第一:什么状态下startService的属于后台启动service;第二:如果想要在后台startService,如何兼容,因此分如下几个问题分析下
看书的小蜗牛
2019/06/11
12.7K0
Android O 后台startService限制简析
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 启动相同 id 的第二个前台 Service 关闭通知 )
上一篇博客 【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 ) 实现了一个前台 Service , 在通知栏 , 存在一个通知 ;
韩曙亮
2023/03/29
2K0
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 启动相同 id 的第二个前台 Service 关闭通知 )
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 )
上一篇博客 【Android 进程保活】提升进程优先级 ( 1 像素 Activity 提高进程优先级 | taskAffinity 亲和性说明 | 运行效果 | 源码资源 ) 使用了前台 Activity , 提升整个进程的优先级 ;
韩曙亮
2023/03/29
2.8K0
【Android 进程保活】提升进程优先级 ( 使用前台 Service 提高应用进程优先级 | 效果展示 | 源码资源 )
Android 8.0 简单适配那些事儿
Android 8.0 以发布很长时间了,基于用户设备和市场要求等迟迟没有适配升级;如今适配时遇到一些问题,整理记录一下!官网 对 Android 8.0 新特性以及适配相关的介绍非常清楚,和尚根据官方要求逐步进行适配升级;
阿策小和尚
2019/08/16
1.3K0
Android 8.0 简单适配那些事儿
Android通知Notification使用全解析,看这篇就够了
通知是 Android 在您的应用 UI 之外显示的消息,用于向用户提供提醒、来自其他人的通信或来自您的应用的其他及时信息。用户可以点击通知打开您的应用或直接从通知中执行操作。
yechaoa
2022/06/27
6.3K0
Android通知Notification使用全解析,看这篇就够了
推荐阅读
相关推荐
Android Q 要来了,一个影响国内 90% App 的适配项!
更多 >
领券
社区富文本编辑器全新改版!诚邀体验~
全新交互,全新视觉,新增快捷键、悬浮工具栏、高亮块等功能并同时优化现有功能,全面提升创作效率和体验
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文