Android 4.4 以上分分钟实现状态栏伪沉浸(状态栏透明)

我们都知道,ios上的状态栏是可以沉浸的,保持了标题栏一样的颜色,这样就让人感觉很高大上,整个屏幕的利用率和风格得到了充分的利用和展现。而在Android中状态栏默认是黑色的(真心不好看),且不会随着App标题栏的颜色改变,使得整个app 的风格看起来不是那么协调.
Android4.4以后,api里边提供了设置状态栏透明的属性,so.我们就可以做一些文章了…
二话不说了,先上几个效果图:
这里写图片描述
这里写图片描述
这里写图片描述
ok!切入正题

  • xml布局
title.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:orientation="vertical"
              android:layout_width="match_parent"
              android:layout_height="wrap_content"
              android:background="#43CD80">
    <TextView
            android:id="@+id/tv_title"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:paddingTop="10dp"
            android:paddingBottom="10dp"
            android:text="透明状态栏测试"
            android:textSize="16sp"
            android:textColor="@android:color/white"/>

</LinearLayout>

在根布局中加入者两个属性,适应系统窗口,防止应用UI跑进状态栏中

android:clipToPadding="true"
android:fitsSystemWindows="true"

注意:如果要设置状态栏透明,padding属性最好不要设在根布局中。
- java代码

private void setImmerseStatue(View view) {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            //透明导航栏                
            getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
            int statusBarHeight = getStatusBarHeight(this.getBaseContext());  
            view.setPadding(0, statusBarHeight, 0, 0);
        }
    }  
    /**
     * 用于获取状态栏的高度。 使用Resource对象获取(推荐这种方式)
     *
     * @return 返回状态栏高度的像素值。
     */
    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;
    }

调用的时候在setContetnt( )后把你的Title的布局作为参数穿进去就ok了.好了,看效果吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值