全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

Android 沉浸式状态栏与隐藏导航栏实例详解

1 前言

一般我们在Android的APP开发中,APP的界面如下:

 

可以看到,有状态栏、ActionBar(ToolBar)、导航栏等,一般来说,APP实现沉浸式有三种需求:沉浸式状态栏,隐藏导航栏,APP全屏

沉浸式状态栏是指状态栏与ActionBar颜色相匹配,

隐藏导航栏不用多说,就是将导航栏隐藏,去掉下面的黑条。

APP全屏是指将状态栏与导航栏都隐藏,例如很多游戏界面,都是APP全屏。

所以,在做这一步时,关键要问清楚产品狗的需求,免得白费功夫。

下面,分别来介绍这三种方式的实现。

2 沉浸式状态栏

沉浸式状态栏效果一般如下:

 

关于沉浸式状态栏网上的方案很多,比如android 5.0 以上的MD设计,或者修改activiyty的window的setStatusBarColor()方法,设置颜色。需要说明一点的时,沉浸式状态栏只对API19以上有效。

这里我依然采用的是设置Activity的Window设置setStatusBarColor()的方法。代码如下:

/**
   * 设置状态栏的颜色
   */
  @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);
    }
  }

效果如下:

这里先调用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);
    }
  }

效果如下:

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

透明状态栏,导航栏:

另外,通过设置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 沉浸式状态栏与隐藏导航栏实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!


# android  # 沉浸式状态栏与隐藏导航栏  # 状态栏  # 导航栏  # Android 中使用RadioGroup和Fragment实现底部导航栏的功能  # 性能分析:指如何快速定位SQL问题  # android中Fragment+RadioButton实现底部导航栏  # Android自定义ViewPagerIndicator实现炫酷导航栏指示器(ViewPager+F  # Android程序开发之Fragment实现底部导航栏实例代码  # Android实现沉浸式通知栏通知栏背景颜色跟随app导航栏背景颜色而改变  # Android实现底部导航栏功能(选项卡)  # 超简单的几行代码搞定Android底部导航栏功能  # Android 弹出Dialog时隐藏状态栏和底部导航栏的方法  # android 全屏去掉底部虚拟导航栏的方法  # 解决android 显示内容被底部导航栏遮挡的问题  # Android仿今日头条顶部导航栏效果的实例代码  # Android仿网易客户端顶部导航栏效果  # Android Fragment实现顶部、底部导航栏  # 全屏  # 是指  # 可以看到  # 左拉  # 小编  # 的是  # 都是  # 就会  # 在此  # 只需  # 要在  # 给大家  # 如果没有  # 又会  # 会把  # 中去  # 多说  # 会将  # 要问 


相关文章: 制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?  如何批量查询域名的建站时间记录?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?  如何设置并定期更换建站之星安全管理员密码?  c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗  如何通过IIS搭建网站并配置访问权限?  如何通过PHP快速构建高效问答网站功能?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  威客平台建站流程解析:高效搭建教程与设计优化方案  php json中文编码为null的解决办法  建站之星与建站宝盒如何选择最佳方案?  学校建站服务器如何选型才能满足性能需求?  如何破解联通资金短缺导致的基站建设难题?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  建站主机是什么?如何选择适合的建站主机?  宝塔新建站点为何无法访问?如何排查?  青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?  如何快速上传建站程序避免常见错误?  临沂网站制作企业,临沂第三中学官方网站?  早安海报制作网站推荐大全,企业早安海报怎么每天更换?  5种Android数据存储方式汇总  网站制作难吗安全吗,做一个网站需要多久时间?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  开封网站制作公司,网络用语开封是什么意思?  设计网站制作公司有哪些,制作网页教程?  香港服务器WordPress建站指南:SEO优化与高效部署策略  如何在云主机上快速搭建网站?  ,网页ppt怎么弄成自己的ppt?  高端建站如何打造兼具美学与转化的品牌官网?  香港服务器租用费用高吗?如何避免常见误区?  宿州网站制作公司兴策,安徽省低保查询网站?  python的本地网站制作,如何创建本地站点?  广东企业建站网站优化与SEO营销核心策略指南  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  临沂网站制作公司有哪些,临沂第四中学官网?  如何选购建站域名与空间?自助平台全解析  如何在IIS管理器中快速创建并配置网站?  深圳网站制作的公司有哪些,dido官方网站?  免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  大型企业网站制作流程,做网站需要注册公司吗?  建站主机默认首页配置指南:核心功能与访问路径优化  如何高效利用200m空间完成建站?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  南京网站制作费用,南京远驱官方网站?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  外贸公司网站制作,外贸网站建设一般有哪些步骤?  公众号网站制作网页,微信公众号怎么制作? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。