现在的app主界面基本上是一个Activity+多个Fragment来实现页面切换的,如果每个Fragment都要实现沉浸式状态栏,一般是布局文件中通过fitsSystemWindows来预留状态栏的位置,但是这样会有一个问题,当多个Fragment添加到Activity中显示后,只有第一个Fragment的fitsSystemWindows起作用了,而其他的都失效了,布局会出现在状态栏的下面。
通过一番探索找到了原因,下面先贴一下Activity的布局界面结构代码。
ConstraintLayout
-FrameLayout
-TabLayout
ConstraintLayout

主界面大概就是这样子的,下面说一下产生的原因,当第一个Fragment添加到Activity中的时候,Activity寻找出有fitsSystemWindows的子布局为其预留出状态栏的空间,其实就是设置一个padding,而其他Fragment添加到Activity中的时候,因为状态栏空间的适配已经被消费过一次了,Activity并不会再次去添加这个padding。因此我们需要自定义一个FrameLayout,重写它的状态栏空间适配的时机和它的适配事件的分发。下面就是核心代码。
public class WindowInsetsFrameLayout extends FrameLayout {
public WindowInsetsFrameLayout(Context context) {
this(context, null);
}
public WindowInsetsFrameLayout(Context context, AttributeS

本文探讨了在使用一个Activity和多个Fragment构建的App界面中,如何处理fitsSystemWindows属性导致的沉浸式状态栏只对第一个Fragment生效的问题。通过分析原因并提供自定义FrameLayout及监听布局变化的解决方案,确保每个Fragment都能正确适配状态栏。
最低0.47元/天 解锁文章

被折叠的 条评论
为什么被折叠?



