安卓进阶

Android 10 从后台启动 Activity 的限制

2022-03-14  本文已影响0人  fyg

背景

在Q版本以前的Android系统,无论在前台或后台应用都可以通过调用startActivity来启动activity,但这会出现一个问题,例如,你正在用Googlemap来导航,但突然弹出了一个其他应用的activity界面。这个行为其实会对用户带来很大的困扰,用户会感到莫名其妙可能会卸载这个突然打开的应用。我们也在Googleplay上收到了一些用户反馈,其中一个用户提到,当他正在拍摄一个子女的重要时刻(毕业典礼或是孩子生日)时突然出现了一个弹出广告,错过了拍摄。所以我们在Q版本中加了一个新的限制:应用只有在有可见的窗口,或是响应用户操作的时候才可以启动Activity。

官网对【从后台启动 Activity 的限制】的说明

image.png

网上资料对【从后台启动 Activity 的限制】的说明

image.png

android官网对【从后台启动 Activity 的限制】描述比较模糊。

个人查阅一下资料后,对这个适配点还是有些疑惑,没有说清楚如何进行限制的。

比如app的Logo页一般都是有倒计时功能的,如果用户单击了app的启动图标后把应用切到后台,当倒计时结束后,没有开启新的activity会如何?
我需要等该应用切换到前台后重新调用一下开启新 activity的代码吗?

经打断点测试,当app切到后台时,启动新activity的代码执行了,但新activity界面没有开启,被系统忽略了,当app切到前台后,被忽略的代码会重新执行一遍。

image.png

1,单击app启动图标进入logo页,打印log: app Foreground on_start
2,app切到后台,打印log: app Background on_stop
3,【 LogoActivity ForegroundExecutor.getInstance().addAndExeTask】 日志是进入下个页面开启新activity的回调切实也执行了。
4.app重新切到前台后日志如下,发现重新走了一下【LogoActivity ForegroundExecutor.getInstance().addAndExeTask】回调,然后进入了MainActivity 页面。

image.png

根据以上推断,一般的应用是不需要适配这个功能点的。因为当app切到前台后,app 会重新执行开启新页面的代码,,如何你的app 被切到后台后,确实有紧急的事情需要用户马上处理的场景,这时可以用通知来完成。

image.png

紧急通知用如下功能完成:

image.png

限制的例外情况,最后一条:

用户已向应用授予 SYSTEM_ALERT_WINDOW 权限的可以开启后台开启activity.

image.png

注意:

在 Android 10(Go 版本)上运行的应用无法获得 SYSTEM_ALERT_WINDOW 权限。


image.png

在如下手机上需要同时开启 【后台弹框界面 和显示悬浮窗】 选项,才能够在后台启动activity (后台应用会把当前应用挤到回台去)。

image.png image.png

在如下手机上只需开启 【后台弹框界面 】 选项,就能够在后台启动activity。

image.png image.png

项目相关代码

public class ForegroundExecutor implements LifecycleObserver {

    private static ForegroundExecutor instance = new ForegroundExecutor();
    public static ForegroundExecutor getInstance(){
        return instance;
    }
    AtomicBoolean isForeground = new AtomicBoolean(true);

    public boolean  isAdapterAndroid10BackgroundStartActivity = false ;
    /**
     * ConcurrentLinkedQueue是并发非阻塞队列
     * ConcurrentLinkedQueue判断队尾条件是节点的next为null
     * 入列出列线程安全,遍历不安全
     * 不允许添加null元素
     */
    public ConcurrentLinkedQueue<Runnable> list = new ConcurrentLinkedQueue<Runnable>();

    public void addAndExeTask(Runnable run){
        if (run == null)
            return;
        list.add(run);
        exeAllTasks();
    }

    public void exeTask(){
        if (!list.isEmpty()){
            Runnable poll = list.poll();
            if (poll != null){
                poll.run();
            }
        }
    }


    public void exeAllTasks(){
        if (isAdapterAndroid10BackgroundStartActivity){
            while (isForeground.get() && !list.isEmpty()){
                exeTask();
            }
        }else{
            exeTask();
        }
    }



    @OnLifecycleEvent(Lifecycle.Event.ON_STOP)
    private void onAppBackground() {
        isForeground.set(false);
        DebugMode.BACKGROUND_MONITOR.showLog("app Background on_stop");
    }

    @OnLifecycleEvent(Lifecycle.Event.ON_START)
    private void onAppForeground() {
        isForeground.set(true);
        DebugMode.BACKGROUND_MONITOR.showLog("app Foreground on_start");
        exeAllTasks();
    }


}

//在appContext 的 onCreate方法中进行注册前后台监听
ProcessLifecycleOwner.get().getLifecycle().addObserver(new ForegroundExecutor());

项目代码:

Github_fullscreenintentexample

简书中markdown如何调整图片大小?

插入图片后上传成功后的图片的链接,最后应该是一个1240的数字,应该是图片的比例,适当调小,就可以把图片按比例缩小了。

参考

从后台启动 Activity 的限制

Android 10(Api 29)新特性适配 - 禁止后台启动Activity

显示紧急消息

限制的例外情况

上一篇 下一篇

猜你喜欢

热点阅读