动态显示和隐藏状态栏

本文通过使用View类的setSystemUiVisibility方法,演示了如何在Android应用中动态操作状态栏,包括显示、隐藏以及全屏显示等不同状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    小米Launcher有一个细节上的功能效果:在长按桌面应用图标时,会隐藏状态栏,然后在状态栏原有的布局上显示卸载或删除的操作栏。放手后,操作栏隐藏,状态栏显示出来。也就是说,这个过程是涉及到对状态栏的动态操作的

    View类提供了setSystemUiVisibility和getSystemUiVisibility方法,这两个方法实现对状态栏的动态显示或隐藏的操作,以及获取状态栏当前可见性。

   setSystemUiVisibility(int visibility)方法可传入的实参为:

    1. View.SYSTEM_UI_FLAG_VISIBLE:显示状态栏,Activity不全屏显示(恢复到有状态的正常情况)。

    2. View.INVISIBLE:隐藏状态栏,同时Activity会伸展全屏显示。

    3. View.SYSTEM_UI_FLAG_FULLSCREEN:Activity全屏显示,且状态栏被隐藏覆盖掉。

    4. View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN:Activity全屏显示,但状态栏不会被隐藏覆盖,状态栏依然可见,Activity顶端布局部分会被状态遮住。

    5. View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION:效果同View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN

    6. View.SYSTEM_UI_LAYOUT_FLAGS:效果同View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN

    7. View.SYSTEM_UI_FLAG_HIDE_NAVIGATION:隐藏虚拟按键(导航栏)。有些手机会用虚拟按键来代替物理按键。

    8. View.SYSTEM_UI_FLAG_LOW_PROFILE:状态栏显示处于低能显示状态(low profile模式),状态栏上一些图标显示会被隐藏。


   下面将以一个demo来验证view的setSystemUiVisibility(int visibility)方法实现动态操作状态栏:

   1.MainActivity代码如下:

package com.example.handlestatusbar;

import android.annotation.SuppressLint;
import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.RelativeLayout;
import android.widget.Toast;

@SuppressLint("NewApi")
public class MainActivity extends Activity implements OnClickListener
{

	private RelativeLayout mRLayout;
	private Button mBtn1, mBtn2, mBtn3, mBtn4, mBtn5, mBtn6, mBtn7, mBtn8;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) 
	{
		super.onCreate(savedInstanceState);
		setContentView(R.layout.main);
		
		mRLayout = (RelativeLayout)findViewById(R.id.content);
		mBtn1 = (Button)findViewById(R.id.btn1);
		mBtn2 = (Button)findViewById(R.id.btn2);
		mBtn3 = (Button)findViewById(R.id.btn3);
		mBtn4 = (Button)findViewById(R.id.btn4);
		mBtn5 = (Button)findViewById(R.id.btn5);
		mBtn6 = (Button)findViewById(R.id.btn6);
		mBtn7 = (Button)findViewById(R.id.btn7);
		mBtn8 = (Button)findViewById(R.id.btn8);
		
		mBtn1.setOnClickListener(this);
		mBtn2.setOnClickListener(this);
		mBtn3.setOnClickListener(this);
		mBtn4.setOnClickListener(this);
		mBtn5.setOnClickListener(this);
		mBtn6.setOnClickListener(this);
		mBtn7.setOnClickListener(this);
		mBtn8.setOnClickListener(this);		
	}
	
	@Override
	public void onClick(View v)
	{
		// TODO Auto-generated method stub
		switch (v.getId()) 
		{
		case R.id.btn1:
			//显示状态栏,Activity不全屏显示(恢复到有状态的正常情况)
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);	
			break;
		case R.id.btn2:
			//隐藏状态栏,同时Activity会伸展全屏显示
			mRLayout.setSystemUiVisibility(View.INVISIBLE);
			break;
		case R.id.btn3:
			//Activity全屏显示,且状态栏被隐藏覆盖掉。
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_FULLSCREEN);
			break;		
		case R.id.btn4:
			//Activity全屏显示,但状态栏不会被隐藏覆盖,状态栏依然可见,Activity顶端布局部分会被状态遮住
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
			break;
			
        case R.id.btn5:
        	//同mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION);
			break;
        case R.id.btn6:
        	//同mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_LAYOUT_FLAGS);
			break;
        case R.id.btn7:
        	//隐藏虚拟按键(导航栏)
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_HIDE_NAVIGATION);
			break;
        case R.id.btn8:
        	//状态栏显示处于低能显示状态(low profile模式),状态栏上一些图标显示会被隐藏。
			mRLayout.setSystemUiVisibility(View.SYSTEM_UI_FLAG_LOW_PROFILE);
			break;
		}
	}

}

    2.布局文件main.xml文件的代码如下:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" 
    android:id="@+id/content">

   <LinearLayout 
       android:orientation="vertical"
       android:layout_width="match_parent"
       android:layout_height="match_parent">
        <Button 
        android:id="@+id/btn1"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s1"/>
    
    <Button 
        android:id="@+id/btn2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s2"/>
    
    <Button 
        android:id="@+id/btn3"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s3"/>
    
    <Button 
        android:id="@+id/btn4"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s4"/>
    
    <Button 
        android:id="@+id/btn5"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s5"/>
    
    <Button 
        android:id="@+id/btn6"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s6"/>
    
    <Button 
        android:id="@+id/btn7"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s7"/>
    
    <Button 
        android:id="@+id/btn8"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/s8"/>
    
   </LinearLayout>
   

</RelativeLayout>
   3.string.xml文件代码如下:    

<?xml version="1.0" encoding="utf-8"?>
<resources>



    <string name="app_name">HandleStatusBar</string>

    <string name="hello_world">Hello world!</string>

    <string name="menu_settings">Settings</string>
    <string name="s1">SYSTEM_UI_FLAG_VISIBLE</string>
    <string name="s2">INVISIBLE</string>
    <string name="s3">SYSTEM_UI_FLAG_FULLSCREEN</string>
    <string name="s4">SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN</string>
    <string name="s5">SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION</string>
    <string name="s6">SYSTEM_UI_LAYOUT_FLAGS</string>
    <string name="s7">SYSTEM_UI_FLAG_HIDE_NAVIGATION</string>
    <string name="s8">SYSTEM_UI_FLAG_LOW_PROFILE</string>
  

</resources>

<think>嗯,用户的问题是关于Android配置导航栏布局的实现方法或代码示例。首先,我需要理解用户的具体需求。导航栏布局可能涉及显示位置、样式定制或者功能调整,比如隐藏或透明导航栏。用户可能在进行界面优化,或者需要适配特定的设备。 根据系统指令,我需要先检查用户提供的引用内容。引用[1]提到在build.gradle中添加Navigation组件的依赖,并创建导航。这可能与使用Android Jetpack Navigation组件有关,用于Fragment之间的导航。引用[2]是关于设置窗口透明导航栏的XML属性,引用[3]涉及Launcher3中禁用widget微件的代码修改,但可能导航栏布局关系不大。 接下来,我需要确定导航栏(Navigation Bar)导航(Navigation)组件的区别。用户可能混淆了这两个概念。导航栏通常指屏幕底部的虚拟按键栏,而Navigation组件用于管理应用内的页面导航,如Fragment切换。因此,需要明确用户的问题指向哪一个方面。 根据用户的问题“android config navigation bar layout example”,可能是指系统导航栏的布局配置,比如调整其外观或行为。这时,引用[2]中的android:windowTranslucentNavigation属性可以用来设置透明导航栏。此外,可能还需要其他方法,如隐藏导航栏或改变其颜色。 另外,引用[1]中的Navigation组件配置,如果用户是想实现应用内的页面导航,比如底部导航栏,那么需要指导如何使用Navigation UIBottomNavigationView。这可能也是用户需要的,尤其是结合Fragment的情况。 需要考虑用户可能的错误,例如混淆了系统导航栏应用内导航组件。因此,在回答中需要区分这两种情况,并提供相应的示例。同时,确保代码示例正确,符合LaTeX格式要求,行内公式用$...$,独立公式用$$...$$,但在这个问题中可能更多是代码块配置说明。 检查是否有其他引用内容相关,引用[3]关于Launcher3的微件禁用,可能与当前问题无关,可以忽略。需要确保引用的正确标注,如透明导航栏的设置来自引用[2],Navigation组件配置来自引用[1]。 最后,生成相关问题时要覆盖导航栏样式调整Navigation组件的使用,帮助用户进一步探索可能的需求。例如,系统导航栏的隐藏、动态修改颜色,或者Navigation组件的深层使用方法。</think>### Android 配置导航栏布局实现方法 #### 1. XML 布局中配置导航栏样式 通过 `values/styles.xml` 定义透明导航栏或调整布局位置: ```xml <style name="AppTheme" parent="Theme.MaterialComponents.DayNight.NoActionBar"> <!-- 设置透明导航栏 --> <item name="android:windowTranslucentNavigation">true</item> <!-- 导航栏颜色 --> <item name="android:navigationBarColor">@color/transparent</item> </style> ``` 此方法适用于全局样式调整[^2]。 --- #### 2. 动态控制导航栏可见性 在 Activity 中通过代码实现沉浸式导航栏: ```kotlin window.decorView.systemUiVisibility = View.SYSTEM_UI_FLAG_HIDE_NAVIGATION or View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY ``` 注意:此方法需要处理手势交互的兼容性。 --- #### 3. 使用 Navigation 组件实现应用内导航 **步骤 1:添加依赖** 在 `build.gradle` 中集成 Navigation 组件: ```groovy dependencies { implementation 'androidx.navigation:navigation-fragment-ktx:2.3.5' implementation 'androidx.navigation:navigation-ui-ktx:2.3.5' } ``` **步骤 2:创建导航图** 在 `res/navigation/nav_graph.xml` 中定义页面跳转逻辑: ```xml <navigation xmlns:android="http://schemas.android.com/apk/res/android"> <fragment android:id="@+id/homeFragment" android:name="com.example.HomeFragment"/> <fragment android:id="@+id/detailFragment" android:name="com.example.DetailFragment"/> </navigation> ``` **步骤 3:绑定到 Activity** 在 MainActivity 中初始化导航控制器: ```kotlin val navController = findNavController(R.id.nav_host_fragment) setupActionBarWithNavController(navController) ``` 此方法实现 Fragment 间的标准化导航[^1]。 --- #### 4. 定制底部导航栏布局 通过 `BottomNavigationView` 实现 Material Design 风格导航栏: ```xml <com.google.android.material.bottomnavigation.BottomNavigationView android:id="@+id/bottom_nav" android:layout_width="match_parent" android:layout_height="wrap_content" app:menu="@menu/bottom_nav_menu"/> ``` 菜单文件 `res/menu/bottom_nav_menu.xml`: ```xml <item android:id="@+id/home" android:icon="@drawable/ic_home" android:title="Home"/> ``` ---
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值