温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

如何在Android应用中实现一个沉浸式状态栏效果

发布时间:2020-12-08 17:04:42 来源:亿速云 阅读:449 作者:Leah 栏目:移动开发

这篇文章将为大家详细讲解有关如何在Android应用中实现一个沉浸式状态栏效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

实现方法如下:

/**
   * 设置状态栏的颜色
   */
  @TargetApi(Build.VERSION_CODES.KITKAT)
  public static void statusBarTintColor(Activity activity, int color) {
    // 代表 5.0 及以上
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
      activity.getWindow().setStatusBarColor(color);
      return;
    }
    // versionCode > 4.4 and versionCode < 5.0
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
      //透明状态栏
      activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
      ViewGroup androidContainer = (ViewGroup) activity.findViewById(android.R.id.content);
      // 留出高度 setFitsSystemWindows true代表会调整布局,会把状态栏的高度留出来
      View contentView = androidContainer.getChildAt(0);
      if (contentView != null) {
        contentView.setFitsSystemWindows(true);
      }
      // 在原来的位置上添加一个状态栏
      View statusBarView = createStatusBarView(activity);
      androidContainer.addView(statusBarView, 0);
      statusBarView.setBackgroundColor(color);
    }
  }
  /**
   * 创建一个需要填充statusBarView
   */
  private static View createStatusBarView(Activity activity) {
    View statusBarView = new View(activity);
    ViewGroup.LayoutParams statusBarParams = new ViewGroup.LayoutParams(
        ViewGroup.LayoutParams.MATCH_PARENT, getStatusBarHeight(activity));
    statusBarView.setLayoutParams(statusBarParams);
    return statusBarView;
  }
  /**
   * 获取状态栏的高度
   */
  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;
  }

3 隐藏导航栏

隐藏导航栏就是使用了UI Flag

/**
   *
   * @param activity
   * @param
   */
  public static void setNavigationBar(Activity activity,int visible){
    View decorView = activity.getWindow().getDecorView();
    //显示NavigationBar
    if (View.GONE == visible){
      int option = SYSTEM_UI_FLAG_HIDE_NAVIGATION;
      decorView.setSystemUiVisibility(option);
    }
  }

4 APP全屏

这里的APP全屏又分为隐藏状态栏与ActionBar,与隐藏导航栏,状态栏。

隐藏状态栏:

/**
   * 设置Activity的statusBar隐藏
   * @param activity
   */
  public static void statusBarHide(Activity activity){
    // 代表 5.0 及以上
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
      View decorView = activity.getWindow().getDecorView();
      int option = View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
      decorView.setSystemUiVisibility(option);
      activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
      ActionBar actionBar = activity.getActionBar();
      actionBar.hide();
      return;
    }
    // versionCode > 4.4 and versionCode < 5.0
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
      activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
    }
  }

效果如下:

如何在Android应用中实现一个沉浸式状态栏效果

这里先调用getWindow().getDecorView()方法获取到了当前界面的DecorView,然后调用它的setSystemUiVisibility()方法来设置系统UI元素的可见性。其中,SYSTEM_UI_FLAG_FULLSCREEN表示全屏的意思,也就是会将状态栏隐藏。另外,根据Android的设计建议,ActionBar是不应该独立于状态栏而单独显示的,因此状态栏如果隐藏了,我们同时也需要调用ActionBar的hide()方法将ActionBar也进行隐藏。

隐藏导航栏,状态栏:

一般游戏需要这种界面,代码如下:

在Activity的onWindowFocusChanged()中去设置界面完全全屏。

 /**
   * 导航栏,状态栏隐藏
   * @param activity
   */
  public static void NavigationBarStatusBar(Activity activity,boolean hasFocus){
    if (hasFocus && Build.VERSION.SDK_INT >= 19) {
      View decorView = activity.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);
    }
  }

效果如下:

如何在Android应用中实现一个沉浸式状态栏效果

可以看到,界面默认情况下是全屏的,状态栏和导航栏都不会显示。而当我们需要用到状态栏或导航栏时,只需要在屏幕顶部向下拉,或者在屏幕右侧向左拉,状态栏和导航栏就会显示出来,此时界面上任何元素的显示或大小都不会受影响。过一段时间后如果没有任何操作,状态栏和导航栏又会自动隐藏起来,重新回到全屏状态。

透明状态栏,导航栏:

另外,通过设置UI Flag,可以让导航栏,状态栏都透明化。

/**
   * 导航栏,状态栏透明
   * @param activity
   */
  public static void setNavigationBarStatusBarTranslucent(Activity activity){
    if (Build.VERSION.SDK_INT >= 21) {
      View decorView = activity.getWindow().getDecorView();
      int option = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
          | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
          | View.SYSTEM_UI_FLAG_LAYOUT_STABLE;
      decorView.setSystemUiVisibility(option);
      activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
      activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
    }
    ActionBar actionBar = activity.getActionBar();
    actionBar.hide();
  }

关于如何在Android应用中实现一个沉浸式状态栏效果就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI