1 Android 控制手机显示或隐藏状态栏的方法
1.1 使用 View 的 setSystemUiVisibility 方法
这个方法允许设置系统 UI 的可见性,包括状态栏。你可以通过组合不同的标志来实现不同的效果。
示例代码:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 获取DecorView,这是Activity的最顶层视图
View decorView = getWindow().getDecorView();
// 设置系统UI的可见性
int uiOptions = View.SYSTEM_UI_FLAG_FULLSCREEN; // 隐藏状态栏
decorView.setSystemUiVisibility(uiOptions);
}
常用的标志:
- View.SYSTEM_UI_FLAG_FULLSCREEN: 隐藏状态栏。
- View.SYSTEM_UI_FLAG_HIDE_NAVIGATION: 隐藏导航栏。
- View.SYSTEM_UI_FLAG_IMMERSIVE: 沉浸式模式,允许用户通过滑动屏幕边缘来显示系统栏。
- View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY: 类似于 IMMERSIVE,但系统栏在显示后会短暂延迟隐藏。
1.2 使用 Window 的 addFlags 和 clearFlags 方法
可以通过Window对象来添加或清除特定的窗口标志,从而控制状态栏的显示。
示例代码:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 获取Window对象
Window window = getWindow();
// 隐藏状态栏
window.addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
// 如果需要再次显示状态栏
// window.clearFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
}
1.3 处理状态栏的重新显示
在某些情况下,如用户滑动屏幕或收到通知,状态栏可能会重新显示。为了确保用户体验的连贯性,你可能需要在onWindowFocusChanged方法中监听窗口焦点的变化,并相应地调整系统UI的可见性。
示例代码:
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
if (hasFocus) {
View decorView = 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); // 沉浸式模式
}
}
1.4 使用 WindowInsetsController 类
在 Android 开发中,随着版本的更新,API 也提供了更加灵活和强大的方法来控制状态栏的显示或隐藏。从 Android R(API级别30)开始,引入了 WindowInsetsController 类,它提供了一种更直观和强大的方式来控制窗口插入(包括状态栏和导航栏)的可见性。
使用 WindowInsetsController,可以实现更精细的控制,比如平滑地隐藏或显示状态栏,以及处理用户与这些系统 UI 元素的交互。
(1)获取 WindowInsetsController 实例
首先,需要在 Activity 或 Fragment 中获取 WindowInsetsController 的实例。这通常通过 Window 对象来实现。
WindowInsetsController