Android在代码中设置状态栏半透明/全透明

2018-12-16 18:14:23


参考网站  Android在代码中设置状态栏半透明/全透明


开发中为了美观需要将状态栏设置为半透明/全透明, 多个界面需求不同,所以需要在代码中来根据不同情况设置


设置之前你需要知道:默认情况下状态栏是有高度的,app内容是在其之下。但是设置半透明/透明之后,状态栏又会覆盖在app内容之上。


情景1:APP顶部是一张图片,你想完成如下这种半透明效果




        if (Build.VERSION.SDK_INT >= 21) {      

            getWindow().setFlags(

                    WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS,

                    WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);

        }

情景2:APP顶部是一张图片,你想完成如下这种透明效果




        if(Build.VERSION.SDK_INT >= 21) {

            Window window = getWindow();

            window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN

                    | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);

            window.setStatusBarColor(Color.TRANSPARENT);

        }

情景3:顶部是有文字,小图标等,如果直接用透明半透明 状态栏上的东西会与内容重叠(你觉得无所谓也可以直接用上面2部分代码),这样我们就想做成类似支付宝这样的效果:




前面说道设置半透明/透明之后状态栏就会覆盖在app内容之上了,所以我们需要在状态栏透明的情况下给app的根视图设置一个paddingTop,值为状态栏的高度。


   /**

     * 利用反射获取状态栏高度

     * @return

     */

    public int getStatusBarHeight() {

        int result = 0;

        //获取状态栏高度的资源id

        int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");

        if (resourceId > 0) {

            result = getResources().getDimensionPixelSize(resourceId);

        }

        return result;

    }

设置paddingTop


        ViewGroup rootView = getWindow().getDecorView().findViewById(android.R.id.main_root);

        rootView.setPadding(0, getStatusBarHeight(), 0, 0);

main_root为根布局ID,然后同情景2,设置状态栏颜色(应用主题色),android SDK>=21


getWindow().setStatusBarColor(Color.BLUE);

SDK<21


            ViewGroup decorView = (ViewGroup) getWindow().getDecorView();

            View statusBarView = new View(this);

            ViewGroup.LayoutParams lp = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,

                    getStatusBarHeight());

            statusBarView.setBackgroundColor(Color.BLUE);

            decorView.addView(statusBarView, lp);

肩膀(参考):https://www.jianshu.com/p/dc20e98b9a90 


         https://blog.csdn.net/d276031034/article/details/52934730


http://www.wufangbo.com/60690/


  • 2019-11-26 11:08:02

    多边型无序点排序(地图绘制多边形)

    任务需求要做一个区域高亮的功能,用到地图,想到了高德地图的多边形API,但是多边形顶点的顺序是要有序的,需求是无序,在API查找无果的情况下,只能手动实现点集合排序。

  • 2019-11-26 11:11:59

    正多边形的编程绘制(javascript)

    如何用程序来绘制正多边形? 在一般情况下,会使用 x = radius * Math.cos(angle), y = radius * Math.sin(angle) 来进行绘制,但这是关于x轴对称的,如果遇到正多边形的边数为奇数,而你又希望它是以y轴对称时,可按照下面的方法。

  • 2019-11-26 13:36:28

    Vue组件命名找不到的问题以及如何给vue组件命名

    首先,Vue 会将 template 中的内容插到 DOM 中,以方便解析标签。由于 HTML 标签不区分大小写,所以在生成的标签名都会转换为小写。例如,当你的 template 为 <MyComponent></MyComponent> 时,插入 DOM 后会被转换为 <mycomponent></mycomponent>。 然后,通过标签名寻找对应的自定义组件。匹配的优先顺序从高到低为:原标签名、camelCase化的标签名、PascalCase化的标签名。例如 <my-component>会依次匹配 my-component、myComponent、MyComponent。camelCase 和 PascalCase 的代码

  • 2019-11-28 11:00:35

    Vue子组件调用父组件的方法

    下面有三种方法,我自己重点推荐第一种,毕竟这种简单粗暴好用好理解,不过这个有一个弊端,再组件嵌套组件的时候,尤其是用第三方组件里面调用自己的子组件的时候,其实已经是孙子组件了,这个时候就要parent.parent。。。。,这样就不好了,我们就得考虑其他方法了,具体怎么判断是父组件,还是爷爷组件,我会单独出一篇文章讲述。