android: targetSdkVersion升级中Only fullscreen activities can request orientation问题的解决方法

 更新时间:2018年09月06日 09:59:53   作者:Hanyu Liu  
这篇文章主要给大家介绍了关于Android target SDK和build tool版本升级中遇到Only fullscreen activities can request orientation问题的解决方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考下

前言

这几天同事跟我在升级Android target SDK和build tool版本的时候,碰到了一个非常搞笑的问题,基本可以算作是“坑”了!我在这里跟大家分享一下,希望对您有所帮助。

特征

当我们把targetSdkVersion升级到27,buildToolsVersion和相关的support library升级到27.0.1后,在Android 8.0(API level 26)上,部分Activity出现了一个莫名其妙的crash,异常信息如下:

java.lang.RuntimeException: Unable to start activity ComponentInfo{com.linkedin.android.XXXX.XXXX/com.linkedin.android.XXXX.XXXX.activity.LoginActivity}: java.lang.IllegalStateException: Only fullscreen activities can request orientation

当你在一个“translucent”的Activity里,试图执行setRequestedOrientation的时候就会触发这个异常。例如:

setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

原因

这个问题貌似已经被广泛的讨论了,最终我们锁定了April 26的一个commit:

Prevent non-fullscreen activities from influencing orientation · aosp-mirror/platform_frameworks_base@3979159

这个改动中抛出异常有关的代码如下:

if (ActivityInfo.isFixedOrientation(requestedOrientation) 
 && !fullscreen
 && appInfo.targetSdkVersion >= O) {
 throw new IllegalStateException("Only fullscreen activities can request orientation");
}

基本的意思是说,“fullscreen”为否的activity是不能锁定orientation的,否则抛出异常。下面,我们在看一下“fullscreen”如何定义的。

public static boolean isTranslucentOrFloating(TypedArray attributes) { 
 final boolean isTranslucent = attributes.getBoolean(com.android.internal.R.styleable.Window_windowIsTranslucent, false); 
 final boolean isSwipeToDismiss = !attributes.hasValue( com.android.internal.R.styleable.Window_windowIsTranslucent) 
          && attributes.getBoolean( com.android.internal.R.styleable.Window_windowSwipeToDismiss, false); 
 final boolean isFloating = attributes.getBoolean(com.android.internal.R.styleable.Window_windowIsFloating, false); 
 return isFloating || isTranslucent || isSwipeToDismiss; 
}

根据上面的定义,如果一个Activity的Style符合下面三个条件之一,认为不是“fullscreen”:

  • “windowIsTranslucent”为true;
  • “windowIsTranslucent”为false,但“windowSwipeToDismiss”为true;
  • “windowIsFloating“为true;

综上可见,这个改动的目的是想阻止非全屏的Activity锁定屏幕旋转,因为当前Activity是透明的,浮动的或可滑动取消的,是否锁屏应该由全屏的Activity决定,而不是并没有全部占据屏幕的Activity决定。

修复

这个问题貌似在最新的SDK中已经修复,我们在API Level 27的设备上已经无法重现,但我们手头的API Level 26的设备还是能重现。而且根据上面的代码来看,如果想保留当前Activity的style,“isTranslucentOrFloating”的逻辑根本没法绕过,所以想绕开很难,目前能想到的大概两个方向:

  • 推迟SDK升级,等官方修复被大多数设备采用;
  • 升级SDK,但重构一下代码,看看已有的非“fullscreen” Activity是不是都是必要的,例如用Fragment实现周围半透明效果,能不能直接把Fragment加入到当前Activity(当然Detach Fragment是有重绘View的开销的)。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • Android实现固定屏幕显示的方法

    Android实现固定屏幕显示的方法

    这篇文章主要介绍了Android实现固定屏幕显示的方法,实例分析了Android屏幕固定显示所涉及的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • Android入门之PopupWindow用法实例解析

    Android入门之PopupWindow用法实例解析

    这篇文章主要介绍了Android入门之PopupWindow用法,对于Android初学者来说有一定的学习借鉴价值,需要的朋友可以参考下
    2014-08-08
  • 安卓Android Context类实例详解

    安卓Android Context类实例详解

    在开发Android的过程中,总是能遇见Context类或者它的实例.Context类的实例经常被用来提供“应用程序”的引用,下面举例说明Contex类实例详解
    2016-07-07
  • 详解Android单元测试最佳实践

    详解Android单元测试最佳实践

    这篇文章主要介绍了详解Android单元测试最佳实践,本文介绍了如何对Android原生应用进行单元测试,同时示例代码采用MVP模式以提高代码的可读性和可测试性
    2018-08-08
  • Android音频焦点管理实例详解

    Android音频焦点管理实例详解

    音频是个专业术语,音频一词已用作一般性描述音频范围内和声音有关的设备及其作用,人类能够听到的所有声音都称之为音频,它可能包括噪音等,下面这篇文章主要给大家介绍了关于Android音频焦点管理的相关资料,需要的朋友可以参考下
    2022-01-01
  • Android检测手机中存储卡及剩余空间大小的方法(基于Environment,StatFs及DecimalFormat)

    Android检测手机中存储卡及剩余空间大小的方法(基于Environment,StatFs及DecimalFormat

    这篇文章主要介绍了Android检测手机中存储卡及剩余空间大小的方法,基于Environment,StatFs及DecimalFormat实现该功能,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-01-01
  • Android实现网络加载时的对话框功能

    Android实现网络加载时的对话框功能

    这篇文章主要介绍了Android实现网络加载时的对话框功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • android开发中ListView与Adapter使用要点介绍

    android开发中ListView与Adapter使用要点介绍

    项目用到ListView,由于要用到 ImageView ,图片源不是在资源里面的,没法使用资源 ID,因此无法直接使用SimpleAdapter,要自己写一个Adapter。 在使用ListView和Adapter需要注意以下几点
    2013-06-06
  • flutter 路由机制的实现

    flutter 路由机制的实现

    本文主要介绍 flutter 中的路由实现原理,包括初始化时的页面加载、切换页面的底层机制等。具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • Android仿抖音列表效果

    Android仿抖音列表效果

    这篇文章主要为大家详细介绍了Android仿抖音列表效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09

最新评论