1.概述
随着安卓4.4版本允许开发者改变状态栏之后,各大App也都选择了进入自己的主题色或背景图片作为状态栏的颜色,较之前的系统默认状态栏相比无疑是提高了用户体验,也让App在这个看脸的社会,更具有吸引力,当然对于自己的作品,有好的东西能实现的肯定要尽可能的实现,毕竟产品的提升就在这点滴之间,下面进入今天的主题吧
2.安卓4.4版本的实现
4.4版本推出后开发者可以使用浸入图片的背景色,但是无法主动的改变颜色,使用也比较简单:
if (Build.VERSION.SDK_INT>= Build.VERSION_CODES.KITKAT)
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
FLAG_TRANSLUCENT_STATUS : 意思很简单就是表面意思,透明状态栏
设置之后你的系统状态栏就会随着你的底色改变颜色了,效果就不展示了,不过你会发现,你的标题或者ToolBar和状态栏重合了,感觉也浸入进去了,这是你需要为浸入的View设置一下属性:
android:fitsSystemWindows="true"
android:clipToPadding="true"
android:fitsSystemWindows="true",就是使用系统的窗口布局,系统还会自动在浸入状态栏的前面加上一个Padding,这样你的view或标题就不会被顶上去了,至于第二个属性,以实际效果来看,写和不写都不会影响最后的布局,不过别以为就这么简单,麻烦由此开始。。。。。
到此你如果在4.4 版本上使用时一切正常,能达到你预期的效果,但是在5.0以上运行的话你会发现状态栏不是完全透明的,而是有半透明的效果,(本人的魅族手机除外,魅族的系统显示的是没有这个半透明的)这就是第一个麻烦,后面会继续分析
3.安卓5.0以上的状态栏
前面已经提到5.0以上的状态栏是一种半透明效果,那就先来认识一下5.0新增改变状态栏的方法,使用过ToolBar的同学应该知道,在stytle文件中就可以设定状态栏和导航栏的颜色,不过5.0以后可以在代码中改变状态栏和导航栏的颜色,现在我们的目的是要和4.4的统一起来,这就需要把半透明颜色改为透明的颜色:
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP){
Window window = getWindow();
window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS | WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION);
window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS );
window.setStatusBarColor(Color.TRANSPARENT);
window.setNavigationBarColor(Color.TRANSPARENT);
}
到此可以让5.0的状态栏变成透明状态
4.遇到的问题
1.ViewPagr+Fragment:
笔者首页使用的是ViewPager可是无论怎么设置Fragment中的View总是会与状态栏重合,而别的界面的Activity和ToolBar都正常,查了一些资料也没有特别好的方法,最后我才用了BUG的一招强行在View的前面添加一个占位空格,使界面布局回复到正常的状态,这里整理一下方便以后查找的同学,这也是我为什么写这篇文章的原因,直接看代码:
首先在xml中写一个占位View
<View
android:id="@+id/view"
android:layout_width="match_parent"
android:layout_height="0dp"></View>
android:id="@+id/view"
android:layout_width="match_parent"
android:layout_height="0dp"></View>
代码中写了一个空的View,之后根据手机状态栏的高度设置其高度达到适配的效果
获取状态栏的高度
public static int getStatusBarHeight(Context context) {
Class<?> c = null;
Object obj = null;
Field field = null;
int x = 0;
try {
c = Class.forName("com.android.internal.R$dimen");
obj = c.newInstance();
field = c.getField("status_bar_height");
x = Integer.parseInt(field.get(obj).toString());
return context.getResources().getDimensionPixelSize(x);
} catch (Exception e1) {
e1.printStackTrace();
return 75;
}
}
Class<?> c = null;
Object obj = null;
Field field = null;
int x = 0;
try {
c = Class.forName("com.android.internal.R$dimen");
obj = c.newInstance();
field = c.getField("status_bar_height");
x = Integer.parseInt(field.get(obj).toString());
return context.getResources().getDimensionPixelSize(x);
} catch (Exception e1) {
e1.printStackTrace();
return 75;
}
}
这个利用反射获取状态栏高度的方法大家应该不陌生吧,肯定多数人都见过
设置占位View的高度
View view1 = view.findViewById(R.id.view);
ViewGroup.LayoutParams layoutParams = view1.getLayoutParams();
layoutParams.height = IContent.getStatusBarHeight(getActivity());
view1.setLayoutParams(layoutParams);
view1.setBackgroundColor(Color.TRANSPARENT);
到这里就可以实现在Fragment上显示的效果了,今天就到这了,当然后面还有因为这个浸入式状态栏而导致的问题后面再继续谈论
网友评论