现在越来越多的软件都开始使用沉浸式状态栏了,下面总结一下沉浸式状态栏的两种使用方法

注意!沉浸式状态栏只支持安卓4.4及以上的版本

状态栏:4.4上是渐变色,5.0上是完全透明,本文模拟器为4.4演示

效果图:

注意!两种方法的区别:

第一种:为顶部栏跟随当前activity的布局文件的背景的颜色,使用方便,不过也有点问题就是,如果有底部虚拟导航键的话,导航键的背景跟顶部的颜色一样,比如:

第二种:是通过设置顶部栏的颜色来显示的,可以解决第一种的不足,比如:

第一种使用方法:

第一、首先在values、values-v19、values-v21文件夹下的styles.xml都设置一个 Translucent System Bar 风格的Theme,如下图:

values/style.xml:

<style name="TranslucentTheme" parent="AppTheme"><!--在Android 4.4之前的版本上运行,直接跟随系统主题-->
</style>
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

values-v19/style.xml:

<style name="TranslucentTheme" parent="Theme.AppCompat.Light.DarkActionBar"><item name="android:windowTranslucentStatus">true</item><item name="android:windowTranslucentNavigation">true</item>
</style>

values-v21/style.xml:

<style name="TranslucentTheme" parent="Theme.AppCompat.Light.DarkActionBar"><item name="android:windowTranslucentStatus">false</item><item name="android:windowTranslucentNavigation">true</item><!--Android 5.x开始需要把颜色设置透明,否则导航栏会呈现系统默认的浅灰色--><item name="android:statusBarColor">@android:color/transparent</item>
</style>

第二、在清单文件中配置需要沉浸式状态栏的activity加入theme

<activity android:name=".ImageActivity" android:theme="@style/TranslucentTheme" />
<activity android:name=".ColorActivity" android:theme="@style/TranslucentTheme" />

第三、在Activity的布局文件中的跟布局加入“android:fitsSystemWindows=”true””,但是,这里需要区分一下,就是背景是图片还是纯色:

1.当背景为图片时,布局可以这么写:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@drawable/imgs_bj"android:fitsSystemWindows="true"></RelativeLayout>
效果:

2.当背景为纯色,我们需要对布局划分一下,标题布局与内容布局,先把根布局背景设置成标题布局的背景色,然后标题背景色可以不用设置直接使用根布局的背景色,最后内容布局背景色设置为白色

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@color/colorPrimary"  //根布局背景设置成“标题布局”想要的颜色android:fitsSystemWindows="true"android:orientation="vertical"><!--标题布局--><RelativeLayout
        android:layout_width="match_parent"android:layout_height="55dp"android:background="@color/color_31c27c"><TextView
            android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:text="这是标题"android:textColor="@android:color/white"android:textSize="20sp" /></RelativeLayout><!--内容布局--><LinearLayout
        android:layout_width="match_parent"android:layout_height="match_parent"android:background="@android:color/white"  //内容区域背景设置成白色android:gravity="center"android:orientation="vertical"><Button
            android:layout_marginTop="120dp"android:layout_width="wrap_content"android:layout_height="wrap_content"android:padding="8dp"android:text="显示信息"android:onClick="showMsg"/></LinearLayout></LinearLayout>

效果图:

好了,以上就是沉浸式状态栏实现的全过程,但是还有一点值得注意的就是,如果我们activity比较多,每一个页面都添加Android:fitsSystemWindows="true" 比较麻烦,我们需要改动一下:

写一个基类BaseColorActivity.class,代码如下:

public abstract class BaseColorActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//这一行注意!看本文最后的说明!!!!supportRequestWindowFeature(Window.FEATURE_NO_TITLE);setContentView(getLayoutResId());//把设置布局文件的操作交给继承的子类ViewGroup contentFrameLayout = (ViewGroup) findViewById(Window.ID_ANDROID_CONTENT);View parentView = contentFrameLayout.getChildAt(0);if (parentView != null && Build.VERSION.SDK_INT >= 14) {parentView.setFitsSystemWindows(true);}}/*** 返回当前Activity布局文件的id** @return*/abstract protected int getLayoutResId();}

然后需要沉浸状态栏的activity继承该基类:

public class ColorActivity extends BaseColorActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);//这里不需要写setContentView()!}@Overrideprotected int getLayoutResId() {//onCreate的方法中不需要写setContentView(),直接把当前activity的布局文件在这里返回就行了!return R.layout.activity_color;}
}

然后需要沉浸状态栏的activity的布局文件中就可以把android:fitsSystemWindows="true"这行代码给省略了!

第二种使用方法(未完):

写个工具类StatusBarCompat.class

public class StatusBarCompat {private static final int INVALID_VAL = -1;private static final int COLOR_DEFAULT = Color.parseColor("#20000000");@TargetApi(Build.VERSION_CODES.LOLLIPOP)public static void compat(Activity activity, int statusColor){//当前手机版本为5.0及以上 if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP){if (statusColor != INVALID_VAL){activity.getWindow().setStatusBarColor(statusColor);}return;}//当前手机版本为4.4if (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);}}public static void compat(Activity activity){compat(activity, INVALID_VAL);}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;}}

使用方法:

在当前activity的onCreate中,调用方法StatusBarCompat.compat就可以了:


//第二个参数是想要设置的颜色
StatusBarCompat.compat(this, Color.RED);

如果嫌每个activity都要写有点麻烦,那就写个基类来完成这一步:

public class BaseActivity extends AppCompatActivity {@Overrideprotected void onCreate(Bundle savedInstanceState) {supportRequestWindowFeature(Window.FEATURE_NO_TITLE);super.onCreate(savedInstanceState);StatusBarCompat.compat(this, Color.RED);}
}

然后每个activity的页面继承该BaseActivity就可以了!

未完待续…………………

关于上面代码中提示注意的那个地方的说明:

隐藏系统title注意的两点:

  1. 继承AppCompatActivity时使用:
    supportRequestWindowFeature(Window.FEATURENOTITLE)

  2. 继承activity时使用:
    requestWindowFeature(Window.FEATURENOTITLE)

Android 沉浸式状态栏的实现方法、状态栏透明相关推荐

  1. android沉浸模式代码,Android沉浸式的两种方法

    隐藏状态栏 一个Android应用程序的界面上其实是有很多系统元素的,观察下图: 而打造沉浸式模式的用户体验,就是要将这些系统元素全部隐藏,只留下主体内容部分. 怎么做呢,郭霖的一个Function搞 ...

  2. android 沉浸式之改变小米魅族状态栏颜色

    这个是基于SystemBarTintManager更改的 增加一个方法:用于更改MIUIV6系统上的状态栏字体颜色 ,目前我仅仅只发现MIUIV6上可以更改,在android5.0上以及其它4.4以上 ...

  3. Android沉浸式效果的实现—Sofia的使用

    Android沉浸式效果的实现,状态栏和导航栏均支持设置颜色.渐变色.图片.透明度.内容入侵和状态栏深色字体:兼容竖屏.横屏,当屏幕旋转时会自动适配. 现在我们的项目中经常需要适配StatusBar和 ...

  4. Android沉浸式模式状态栏(二)

    其实说到沉浸式状态栏这个名字,真不知道这种叫法是谁先发起的.因为Android官方从来没有给出过沉浸式状态栏这样的命名,只有沉浸式模式(Immersive Mode)这种说法.而有些人在没有完全了解清 ...

  5. 高大上的Android沉浸式状态栏?

    背景 之前做过Android沉浸式状态栏的相关需求,但是一直忙于工作,没时间系统的整理下沉浸式相关的知识,所以今天抽出时间,写一篇 Android沉浸式状态栏的文章. 何为沉浸式 沉浸式就是要给用户提 ...

  6. Android 沉浸式状态栏 实现方式二 ( 更简单 )

    以前写过一个沉浸式状态栏 的实现方式 Android 沉浸式状态栏 实现方式一 现在有个更为简单的实现方式 . 相关链接 http://www.apkbus.com/forum.php?mod=vie ...

  7. android 沉浸式开源库,Android沉浸式状态栏

    关于Android沉浸式状态栏, 网上已经有很多开源库, 虽然开源库可以解决某些特定布局下的沉浸式状态栏问题, 但是遇到比较特殊的布局就无法解决了, 所以了解一下沉浸式状态栏如何实现是有必要的. 无论 ...

  8. android沉浸式 字体,Android沉浸式状态栏背景色以及字体颜色的修改

    在activity中设置透明状态栏 的思路: 1.让activity的布局全屏 此时布局会和状态栏重叠 2.让布局最上方预留出和状态栏高度一样的高度,将状态栏的背景色设置为透明 效果如下: 一般是在s ...

  9. Android沉浸式状态栏(透明状态栏)最佳实现

    Android沉浸式状态栏(透明状态栏)最佳实现 在Android4.4之前,我们的应用没法改变手机的状态栏颜色,当我们打开应用时,会出现上图中左侧的画面,在屏幕的顶部有一条黑色的状态栏,和应用的风格 ...

  10. Android 沉浸式状态栏 渐变颜色的实现

    Android 沉浸式状态栏 渐变颜色的实现 最近在开发中遇到一种个性化的需求,类似于QQ顶部的渐变状态栏的实现,如下图 首先我们要了解在Android5.0以后,系统API提供直接设置StatusB ...

最新文章

  1. 用ASP.Net(C#)连接Oracle数据库的方法
  2. YAML配置:mapping values are not allowed here
  3. Leetcode: Remove Element
  4. 组会PPT20200522《Summary of Study and Research from May 8 to May 21》
  5. 佳顺通用进销存系统去广告_免费OA办公系统的问题汇总回答
  6. 【C/C++】代码换行问题
  7. 分布式ID业界解决方案
  8. 点击开启此虚拟机时,出现“该虚拟机似乎正在使用中”问题
  9. Flash 二进制传图片到后台Java服务器接收
  10. Excel学习笔记:P22-时间格式、工龄与工时计算
  11. vs2017使用教程
  12. 制作你喜欢的双系统启动菜单—VistaBootPRO
  13. Android播放音乐的代码,android源代码(完整的音乐播放器)
  14. 【Linux c】sipc
  15. Android 项目必备(十七)-->实现身份证认证功能
  16. 架构--网络关键指标公式
  17. TypeScript进阶 之 重难点梳理
  18. 想了解自动驾驶系统,看完这一篇就够了......
  19. 王者农药新模式——智慧王者 树形递归
  20. 在word中通过endnote打入文献标签

热门文章

  1. mysql 同步 存储过程_mysql 存储过程 实现数据同步
  2. 页面怎么创建一个数组_怎么创建一个企业网站?
  3. string 日期比较_java8-新的日期API
  4. C++知识点8——函数的返回值
  5. java整数转二进制字符串_在Java中将int转换为二进制字符串表示形式?
  6. 常见设计模式,单例模式(双重检测锁方式)示例
  7. C++ 基本数据类型
  8. WebApi与Mvc的区别
  9. 2018-01-24
  10. Java 9 揭秘(16. 虚拟机栈遍历)