美文网首页
安卓浸入式状态栏

安卓浸入式状态栏

作者: AlexTiti | 来源:发表于2017-05-20 14:30 被阅读0次

    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>

    代码中写了一个空的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;
    }
    }

    这个利用反射获取状态栏高度的方法大家应该不陌生吧,肯定多数人都见过


    设置占位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上显示的效果了,今天就到这了,当然后面还有因为这个浸入式状态栏而导致的问题后面再继续谈论



    相关文章

      网友评论

          本文标题:安卓浸入式状态栏

          本文链接:https://www.haomeiwen.com/subject/jqcpxxtx.html