当前位置:   article > 正文

Android 沉浸式状态栏与隐藏导航栏_android 沉浸式状态栏bug 界面整体向下移

android 沉浸式状态栏bug 界面整体向下移

1 前言

一般我们在Android的APP开发中,APP的界面如下: 
这里写图片描述 
可以看到,有状态栏、ActionBar(ToolBar)、导航栏等,一般来说,APP实现沉浸式有三种需求:沉浸式状态栏,隐藏导航栏,APP全屏 
沉浸式状态栏是指状态栏与ActionBar颜色相匹配, 
隐藏导航栏不用多说,就是将导航栏隐藏,去掉下面的黑条。 
APP全屏是指将状态栏与导航栏都隐藏,例如很多游戏界面,都是APP全屏。 
所以,在做这一步时,关键要问清楚产品狗的需求,免得白费功夫。 
下面,分别来介绍这三种方式的实现。

2 沉浸式状态栏

沉浸式状态栏效果一般如下: 
顺便在网上找的图 
这里写图片描述 
关于沉浸式状态栏网上的方案很多,比如android 5.0 以上的MD设计,或者修改activiyty的window的setStatusBarColor()方法,设置颜色。需要说明一点的时,沉浸式状态栏只对API19以上有效。 
这里我依然采用的是设置Activity的Window设置setStatusBarColor()的方法。代码如下:

  1. /**
  2. * 设置状态栏的颜色
  3. */
  4. @TargetApi(Build.VERSION_CODES.KITKAT)
  5. public static void statusBarTintColor(Activity activity, int color) {
  6. // 代表 5.0 及以上
  7. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
  8. activity.getWindow().setStatusBarColor(color);
  9. return;
  10. }
  11. // versionCode > 4.4 and versionCode < 5.0
  12. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
  13. //透明状态栏
  14. activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
  15. ViewGroup androidContainer = (ViewGroup) activity.findViewById(android.R.id.content);
  16. // 留出高度 setFitsSystemWindows true代表会调整布局,会把状态栏的高度留出来
  17. View contentView = androidContainer.getChildAt(0);
  18. if (contentView != null) {
  19. contentView.setFitsSystemWindows(true);
  20. }
  21. // 在原来的位置上添加一个状态栏
  22. View statusBarView = createStatusBarView(activity);
  23. androidContainer.addView(statusBarView, 0);
  24. statusBarView.setBackgroundColor(color);
  25. }
  26. }
  27. /**
  28. * 创建一个需要填充statusBarView
  29. */
  30. private static View createStatusBarView(Activity activity) {
  31. View statusBarView = new View(activity);
  32. ViewGroup.LayoutParams statusBarParams = new ViewGroup.LayoutParams(
  33. ViewGroup.LayoutParams.MATCH_PARENT, getStatusBarHeight(activity));
  34. statusBarView.setLayoutParams(statusBarParams);
  35. return statusBarView;
  36. }
  37. /**
  38. * 获取状态栏的高度
  39. */
  40. public static int getStatusBarHeight(Context context) {
  41. int result = 0;
  42. int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
  43. if (resourceId > 0) {
  44. result = context.getResources().getDimensionPixelSize(resourceId);
  45. }
  46. return result;
  47. }

3 隐藏导航栏

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

  1. /**
  2. *
  3. * @param activity
  4. * @param
  5. */
  6. public static void setNavigationBar(Activity activity,int visible){
  7. View decorView = activity.getWindow().getDecorView();
  8. //显示NavigationBar
  9. if (View.GONE == visible){
  10. int option = SYSTEM_UI_FLAG_HIDE_NAVIGATION;
  11. decorView.setSystemUiVisibility(option);
  12. }
  13. }
  • 1

4 APP全屏

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

  1. /**
  2. * 设置Activity的statusBar隐藏
  3. * @param activity
  4. */
  5. public static void statusBarHide(Activity activity){
  6. // 代表 5.0 及以上
  7. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
  8. View decorView = activity.getWindow().getDecorView();
  9. int option = View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN;
  10. decorView.setSystemUiVisibility(option);
  11. activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
  12. ActionBar actionBar = activity.getActionBar();
  13. actionBar.hide();
  14. return;
  15. }
  16. // versionCode > 4.4 and versionCode < 5.0
  17. if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
  18. activity.getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
  19. }
  20. }

效果如下: 
这里写图片描述

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

隐藏导航栏,状态栏: 
一般游戏需要这种界面,代码如下: 
在Activity的onWindowFocusChanged()中去设置界面完全全屏。

  1. /**
  2. * 导航栏,状态栏隐藏
  3. * @param activity
  4. */
  5. public static void NavigationBarStatusBar(Activity activity,boolean hasFocus){
  6. if (hasFocus && Build.VERSION.SDK_INT >= 19) {
  7. View decorView = activity.getWindow().getDecorView();
  8. decorView.setSystemUiVisibility(
  9. View.SYSTEM_UI_FLAG_LAYOUT_STABLE
  10. | View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
  11. | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
  12. | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
  13. | View.SYSTEM_UI_FLAG_FULLSCREEN
  14. | View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY);
  15. }
  16. }

效果如下: 
这里写图片描述

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

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

  1. /**
  2. * 导航栏,状态栏透明
  3. * @param activity
  4. */
  5. public static void setNavigationBarStatusBarTranslucent(Activity activity){
  6. if (Build.VERSION.SDK_INT >= 21) {
  7. View decorView = activity.getWindow().getDecorView();
  8. int option = View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
  9. | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
  10. | View.SYSTEM_UI_FLAG_LAYOUT_STABLE;
  11. decorView.setSystemUiVisibility(option);
  12. activity.getWindow().setNavigationBarColor(Color.TRANSPARENT);
  13. activity.getWindow().setStatusBarColor(Color.TRANSPARENT);
  14. }
  15. ActionBar actionBar = activity.getActionBar();
  16. actionBar.hide();
  17. }

效果如下: 
这里写图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/960263
推荐阅读
相关标签
  

闽ICP备14008679号