沉浸式状态栏实现

关于沉浸式状态栏说法一般持有2种观念:
1.设置statusbar并不是真正的沉浸式,所谓的沉浸式应该不带一丝杂质
实现过程:

 @Override
    public void onWindowFocusChanged(boolean hasFocus) {
        super.onWindowFocusChanged(hasFocus);
        if (hasFocus && Build.VERSION.SDK_INT >= 19) {
            View decorView = getWindow().getDecorView();
            decorView.setSystemUiVisibility(
                View.SYSTEM_UI_FLAG_LAYOUT_STABLE
                | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
                | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
                | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
                | View.SYSTEM_UI_FLAG_FULLSCREEN
                | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY);
        }
    }

你想显示statusbar和底部导航只需要在边缘滑动就会出来;
2.使用设置状态栏透明,但这样你所设置的toolbar会向上占位,所以我们获取状态栏的高度如下 :

  public static int getStatusBarHeight(Context context) {
            int result = 0;
            int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
            if (resourceId > 0) {
                result = context.getResources().getDimensionPixelSize(resourceId);
            }
            return result;
        }

4.4版本和5.0以上版本的设置方法不同所以我们要做适配方法如下:

 public static void compat(Activity activity, int statusColor) {

        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
            if (statusColor != INVALID_VAL) {
                activity.getWindow().setStatusBarColor(statusColor);
            }
            return;
        }
        // KITKAT 4.4  LOLLIPOP 5.0
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
            int color = COLOR_DEFAULT;
            ViewGroup contentView = (ViewGroup) activity.findViewById(android.R.id.content);
            if (statusColor != INVALID_VAL) {
                color = statusColor;
            }
            View statusBarView = new View(activity);
            ViewGroup.LayoutParams lp = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
                    getStatusBarHeight(activity));
            statusBarView.setBackgroundColor(color);
            contentView.addView(statusBarView, lp);
        }

    }

如果是5.0以上就直接设置statusBar的颜色,如果是在4.4与5.0直接就需要创建一个view高度为获取的状态栏高度进行占位,不然就挤到一起去了;
踩坑提示:1.因为是要占位所以你的toolbar 如果是通过include它的父布局一定要是LinearLayout ,并且设置
height为wrapcontent ,并添加属性android:fitsSystemWindows=”true”
2.要在setContentView后在调用compat(Activity ,int statusColor ) 方法;
接着就是这种状态栏为透明了,代码设置或创建一个values-19,values-21都可以
values-19

<resources>


    <!-- Base application theme. -->
    <style name="AppTheme" parent="@style/BaseAppTheme">
        <item name="android:windowTranslucentStatus">true</item>
    </style>

</resources>

values-21

<resources>


    <!-- Base application theme. -->
    <style name="AppTheme" parent="@style/BaseAppTheme">

    </style>
</resources>

以上2种方法都讲完了,根据项目的需要可以选择不同的方式;

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值