Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置

文章目录

  • 实例图片
    • 状态栏
    • 标题栏
    • 导航栏
    • 系统栏
    • 应用栏
    • actionBar和toolBar的区别
      • ActionBar
        • 代码:
        • 显示结果:
        • ActionBar显示选项菜单项
      • ToolBar
        • Toolbar的使用

实例图片

Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第1张图片
如上图,可以看到,有状态栏(status bar)、标题栏(action bar, toolbar)、导航栏(navigation bar) 等,

状态栏

状态栏 (status bar):是指手机最顶上,显示中国移动、安全卫士、电量、网速等等,在手机的顶部。下拉就会出现通知栏。

标题栏

标题栏就是指action bar/toolbar,app程序最上边的titlebar。关于actionBar和toolBar后面介绍

导航栏

NavigationBar:现在很多手机省略了导航栏,一般指手机下面的返回、home、菜单三个键,图片上的导航栏为APP的 导航栏。

系统栏

SystemBar:状态栏+导航栏 (参考:(参考:https://developer.android.google.cn/training/system-ui/dim))

应用栏

应用栏(app bar):应用栏也称操作栏,一般是把标题栏(Toolbar) 设置为应用栏 (参考:https://developer.android.google.cn/training/appbar/)

actionBar和toolBar的区别

ActionBar

Actionbar是Android3.0之后的一个重要的交互元素,Actionbar位于Activity的顶部,用于显示图标、菜单、标题,广泛用于View的交互、导航等功能。在Android3.0之后,Actionbar是默认添加的,只要你新建的Activity继承于AppCompatActivity,Actionbar是默认添加的。如果是继承的Activity,ActionBar是不显示的,即不显示状态栏。

代码:

import androidx.appcompat.app.ActionBar;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import com.example.androidlearn.R;

public class ActionBarMainActivity extends AppCompatActivity {

    private ActionBar actionBar;
    @Override
    protected void onCreate(Bundle savedInstanceState)
    {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_action_bar_main);
        // 获取该Activity的ActionBar
        // 只有当应用主题没有关闭ActionBar时,该代码才能返回ActionBar
        actionBar = getSupportActionBar(); //使用的是getSupportActionBar 导入的包是androidx的包
    }
    // 为“显示ActionBar”按钮定义事件处理方法
    public void showActionBar(View source)
    {
        // 显示ActionBar
        actionBar.show();
    }
    // 为“隐藏ActionBar”按钮定义事件处理方法
    public void hideActionBar(View source)
    {
        // 隐藏ActionBar
        actionBar.hide();
    }
}

显示结果:

Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第2张图片

1.继承的是AppCompatActivity 然后使用的是getSupportActionBar。才能正常使用actionBar

标题栏显示label设置

  • activity 里面的 android:label 优先级 > application 里面的android:label
  • android:label属性 用来设定apk的名称以及activity的标题。

代码:
Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第3张图片
显示:
apk名称显示
Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第4张图片
activity标题显示
Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第5张图片
改变标题的内容也可以在代码中使用

setTitle()

ActionBar显示选项菜单项

1.创建Menu资源文件
Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第6张图片

Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第7张图片

  • always :表示总是将MenuItem显示在ActionBar上
  • collapseActionView :将该ActionView折叠成普通菜单项
  • ifRoom :当ActionBar位置足够时才显示MenuItem
  • never :不将该MenuItem显示在ActionBar上
  • withText :将该MenuItem显示在ActionBar上,并显示该菜单项的文本
  1. 重写onCreateOptionMenu创建菜单项方法和onOptionItemSelected方法设置监听事件
    Android 标题栏、状态栏、系统栏、导航栏、应用栏及各个位置的颜色设置_第8张图片
    3.显示效果

ToolBar

Android3.0之后,Google引入了ActionBar,想要统一安卓应用的导航栏样式。但是由于ActionBar难以定制,很大程度上限制了开发人员。较为常见的实现是使用普通的ViewGroup来封装自己的APP Bar,或者使用JakeWharton大神的ActionBarSherlock库。
自2014年Google I/O上Material Design横空出世后,市场上的应用又逐步趋向了样式的风格统一,support library中很快就出来了ToolBar控件,一个定制化的ViewGroup,来完善ActionBar的使用。
ToolBar是ActionBar的替代品。

Toolbar的使用

直接引入ToolBar组件

 <androidx.appcompat.widget.Toolbar
        android:id="@+id/toolBar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:logo="@mipmap/ic_launcher"
        app:title="Toolbar"
        app:subtitle="subtitle">

Activity中编写

代码有两个地方需要注意:

public class ToolBarMainActivity extends AppCompatActivity {

    private Toolbar toolbar;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        // 隐藏掉ActionBar 一定要在setContentView(R.layout.activity_main)之前设置。
        supportRequestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_tool_bar_main);
        toolbar = findViewById(R.id.toolBar);
        /**
         * AppCompatActivity是默认有标题栏的(ActionBar),你要使用Toolbar,就得替代掉原先的ActionBar
         * 要不然加菜单文件不显示
         */
        setSupportActionBar(toolbar);
    }

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.action_bar_menu,menu);
        return super.onCreateOptionsMenu(menu);
    }

你可能感兴趣的:(android,android)