对于 android5.0 以上的状态栏沉浸方法,我看到的大部分说法是下面的style
<style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <!-- Customize your theme here. --> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> <item name="android:windowTranslucentStatus">false</item> <item name="android:windowTranslucentNavigation">true</item> <item name="android:statusBarColor">@android:color/transparent</item> </style>
刚开始我也是这么用的,似乎没有什么问题,但是后来发现在有底部虚拟按键的设备上,我的应用布局会和三个虚拟按键重叠,但是我想要的效果是我的布局在虚拟键之上
于是我去掉了这句话
<item name="android:windowTranslucentNavigation">true</item>
然后我的状态栏却不再沉浸了,不太清除这句话为什么会影响状态栏,看起来好像只会影响底部虚拟键的样子
于是另找解决办法,实现了沉浸状态栏的同时布局位于虚拟键之上
核心代码如下,java代码和item需要同时使用
代码中加上这段代码
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) try { Class decorViewClazz = Class.forName("com.android.internal.policy.DecorView"); Field field = decorViewClazz.getDeclaredField("mSemiTransparentStatusBarColor"); field.setAccessible(true); field.setInt(getWindow().getDecorView(), Color.TRANSPARENT); //改为透明 } catch (Exception e) { }
扫描二维码关注公众号,回复:
2639174 查看本文章
style中加上下面的item
<item name="android:windowTranslucentStatus">true</item>
原理参考下文,好像是用反射解决的,链接如下