前言
这次刚好有时间让自己提升一下自己的技能,一直以来我对导航栏沉浸式模式一直停留在比较基础的阶段,趁这段时间查漏补缺。差不多翻了一遍网上所有关于沉浸式的微博,现在自己来总结一下我所学到的知识点,方便我之后用到的时候,能够快速利用起来。
沉浸式是什么
我看到一篇将沉浸式发展历史的,讲的非常好,看完之后,让我对软件开发迭代的理解有了新的见解(人家谷歌这么大的公司写软件也不是一步到位的,也是慢慢整改的一个过程,先解决有没有的问题,然后想到更好的方案再慢慢优化。毕竟我自己写的app兼容性的影响没有Android系统那么大,大不了强制升级啊,没有必要太过谨慎的。)说了这么多,文章在哪呢——>Android沉浸式UI,看这一篇就够了,带你了解沉浸式的前世今生。到现在还没抛出概念,我来自己总结一下,就是想要通过透明或改变颜色等方式改变状态栏的展示形式。
入个门
入门看郭霖的博客是不错的选择,毕竟他是写Android入门书籍的大神。
Android状态栏微技巧,带你真正理解沉浸式模式,那就动手在我们的app整改一下吧,果断在BaseActivity里面加了下面这段代码。
if (Build.VERSION.SDK_INT >= 21) {
View decorView = getWindow().getDecorView();
int option = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
| View.SYSTEM_UI_FLAG_LAYOUT_STABLE;
decorView.setSystemUiVisibility(option);
getWindow().setNavigationBarColor(Color.TRANSPARENT);
getWindow().setStatusBarColor(Color.TRANSPARENT);
}
看一下实际效果所有的界面都往上移了一个状态栏的距离,样子好丑。
很显然入门级方法不适用到我们实际生产当中,那就换一个方法吧。
先罗列一下入门级方法存在的问题,带着问题来一个个解决更容易理解。
1.看过上文提到的介绍历史的博文,翻过其他博客的同学肯定会知道,沉浸式一般以Android4.4版本为分界线,开始可以实现透明的状态栏(其实是渐变的半透明,同样的属性值在5.0上有不同的显示效果),然后是5.0版本从这里开始状态栏的颜色可以改变了,6.0开始可以改变状态栏内容的颜色。那么入门级的这篇文章根本就没有提到兼容性的问题,因为我们实际生产过程中不可能要求客户一定要用最新版本的手机(定制等特殊情况除外)。我们的APP至少要覆盖绝大多数的Android版本。
2.状态栏占位的问题,可以看到上图的搜索框那一栏合理的位置应该是放在状态栏的下面,而不能是和状态栏有重叠。
3.状态栏背景颜色问题,办法都是想出来的,虽然之前的版本可能不是那么完善,没有相关的API,但是,我们可以在相应的设计上作出适当的调整。比如微信的界面顶端设置成黑色的标题栏,那么不管你状态栏是4.4还是5.0,用户看到的就是纯黑色的。再比如支付宝界面顶部单纯就是一个透明的状态栏,那么我们是不是就可以在界面顶部添加一个状态栏大小的透明条条呢。
解决方案
-
Android UI体验之全屏沉浸式透明状态栏效果这篇文章就是给界面顶部添加一个view然后涂上颜色的方案。
这里我还看到另一篇通过反射来获取状态栏高度的(Android之沉浸式状态栏的实现),这里仅仅是为了记录一下获取状态栏的另一种方式,大家可以忽略这句话。
/**
* 通过反射的方式获取状态栏高度
* @return
*/
private int getStatusBarHeight() {
try {
Class<?> c = Class.forName("com.android.internal.R$dimen");
Object obj = c.newInstance();
Field field = c.getField("status_bar_height");
int x = Integer.parseInt(field.get(obj).toString());
return getResources().getDimensionPixelSize(x);
} catch (Exception e) {
e.printStackTrace();
}
return 0;
}
Android开发:Translucent System Bar 的最佳实践
Android开发笔记(一百六十三)高仿京东的沉浸式状态栏
Android沉浸式(透明)状态栏适配
Android 沉浸式状态栏的实现
要深刻理解android:fitsSystemWindows属性的一定要看这两篇文章
[Digging]android:fitsSystemWindows
全屏、沉浸式、fitSystemWindow使用及原理分析:全方位控制“沉浸式”的实现
未完待续