参考资料:
一. 沉浸式状态栏发展简介
从Android4.4到现在,沉浸式的发展大概可以分为三个阶段:
- Android4.4(API 19) - Android 5.0(API 21): 这个阶段可以实现沉浸式,但是表现得不是很好。实现方式为: 通过FLAG_TRANSLUCENT_STATUS设置状态栏为透明并且为全屏模式,然后通过添加一个与StatusBar 一样大小的View,将View 的 background 设置为我们想要的颜色,从而来实现沉浸式。
- Android 5.0(API 21)以上版本: 在Android 5.0的时候,加入了一个重要的属性和方法 android:statusBarColor (对应方法为 setStatusBarColor),通过这个方法我们就可以轻松实现沉浸式。也就是说,从Android5.0开始,系统才真正的支持沉浸式。
- Android 6.0(API 23)以上版本:其实Android6.0以上的实现方式和Android 5.0 +是一样,为什么要将它归为一个单独重要的阶段呢?是因为从Android 6.0(API 23)开始,我们可以改状态栏的绘制模式,可以显示白色或浅黑色的内容和图标。
二. 具体方案(Android5.0及以上版本)
经过调研总结,我选择以这样的方式来解决沉浸式状态栏问题,只需两步:
- 设置状态栏透明,将布局扩展到状态栏
- 为需要的布局设置合适的paddingTop,达到整体向下移的效果
这样做有以下3点好处:
- 不用判断系统版本,适配于5.0以上的所有机型;
- 不用在xml或style中设置其它属性,全部采用代码实现,统一适配;
- 适合沉浸式头部控件高度有变化的情景,可以不用在代码中频繁计算控件高度。
三. 典型情景适配方案
- 状态栏颜色适配(TestActivity)
只需要通过setStatusBarColor(@ColorInt int color)方法设置状态栏的颜色即可。
状态栏颜色设置- 头部高度确定 (UnChangeActivity)
1)设置状态栏透明,并将布局扩展到状态栏
2)给需要的布局整体添加paddingTop
考虑到后期头部扩展,建议采用第三种方案实现。
头部高度确定- 头部高度不确定(MainActivity)
1)设置状态栏透明,并将布局扩展到状态栏
2)推荐利用自定义的ToolBarHasPadding和LineLayoutHasPadding来实现布局的下移,背景图片通过ImageView来显示,将ImageView的高度约束起来自适应大小。
头部高度不确定
网友评论