共计 9900 个字符,预计需要花费 25 分钟才能阅读完成。
Android 的标题栏和状态栏
标题栏和状态栏是每一个 Android 开发都要去解决的
一:标题栏
你关上任何一个 App 都有绝对应的标题栏,那么 Android 零碎提供给咱们的标题栏是什么了
咱们 Android Studio 创立一个利用
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:roundIcon="@mipmap/ic_launcher_round"
android:supportsRtl="true"
android:theme="@style/Theme.MyTest">// 这个 Application 节点给咱们一个默认的主题格调,这样的话整个 app 的主题格调都是这个,咱们也能够设置本人的 activity 的主题格调
<activity android:name=".MainActivity"
android:theme="@style/ss">// 这个设置了本人 Activity 的主题格调
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
咱们先看一下默认当初的主题格调是什么
<style name="Theme.MyTest" parent="Theme.MaterialComponents.DayNight.DarkActionBar">
<!-- Primary brand color. -->
<item name="colorPrimary">@color/purple_500</item>// 您的利用的次要品牌色彩,次要用于主题
<item name="colorPrimaryVariant">@color/purple_700</item>// 您的次要品牌色彩的较浅 / 较暗变体,在主题中很少应用
<item name="colorOnPrimary">@color/white</item>// 用于显示在原色上方的元素的色彩(例如,文本和图标,依据可拜访性,通常为红色或半透明的彩色)<!-- Secondary brand color. -->
<item name="colorSecondary">@color/teal_200</item>// 您应用程式的主要品牌色调,次要用于强调某些须要突出的小部件
<item name="colorSecondaryVariant">@color/teal_700</item>// 您的主要品牌色彩的较浅 / 较深变体,在主题中很少应用
<item name="colorOnSecondary">@color/black</item>// 用于显示在辅助色彩顶部的元素的色彩
<!-- Status bar color. -->
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item>// 状态栏应用的色彩
<!-- Customize your theme here. -->
</style>
默认的父类的主题格调是 parent=”Theme.MaterialComponents.DayNight.DarkActionBar”
这个主题就是 Android 标准设计格调 Material 和之前的 Theme.AppCompat.DayNight.DarkActionBar 没什么大的区别,也都有不带 ActionBar 的主题格调 Theme.AppCompat.DayNight.NoActionBar,Theme.MaterialComponents.DayNight.NoActionBar 还有好多种主题格调,当前钻研专门讲
<style name="ss" parent="Theme.AppCompat.DayNight.DarkActionBar">
<item name="colorPrimary">@color/red</item>// 这个设置标题栏的色彩
<item name="colorPrimaryDark">@color/green</item>// 这个设置状态栏的色彩
<item name="colorAccent">@color/blue</item><!-- 管制各个控件被选中时的色彩 --><!--windowActionBar 能够设置没有标题栏 -->
item name="windowActionBar">false</item>
<!--windowNoTitle 能够设置没有标题栏 -->
<item name="windowNoTitle">true</item>
</style>
形式一:这个能够设置 appliction 和 activty 主题格调都能够
<item name=”windowActionBar”>false</item>
<item name=”windowNoTitle”>true</item>
这 2 个在主题中能够去掉标题栏
形式二:在代码中应用 requestWindowFeature 也能够去掉标题栏
@Override
protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);// 去掉标题栏留神这句肯定要写在 setContentView()办法的后面,不然会报错的,这个只针对特定的页面 Activty
setContentView(R.layout.activity_main);
}
形式三:就是 Theme.AppCompat.DayNight.NoActionBar 间接设配 NoActionBar 主题格调
二:状态栏
去掉状态栏(状态栏个别不去掉)
形式一:代码实现
@Override
protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);
// requestWindowFeature(Window.FEATURE_NO_TITLE);// 去掉标题栏留神这句肯定要写在 setContentView()办法的后面,不然会报错的
getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
WindowManager.LayoutParams.FLAG_FULLSCREEN);// 去掉状态栏,然而变成彩色暗影
setContentView(R.layout.activity_main);
}
形式二:主题格调设置全屏
<item name=”android:windowFullscreen”>true</item>// 这些都是针对之前零碎版本的
咱们要设置全面屏
咱们状态栏这只能通明的
/**
* 设置状态栏通明,启用全屏模式
* @param activity
*/
@TargetApi(19)
public static void transparencyBar(Activity activity) {if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {Window window = activity.getWindow();
window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
window.setStatusBarColor(Color.TRANSPARENT);
window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_STABLE | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN);
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {Window window = activity.getWindow();
window.setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS, WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}
}
针对状态栏批改状态栏的为全面屏,和状态栏的字体色彩变动,变黑,和变白种不同的办法
public class StatusBarUtil {
/**
* 批改状态栏为全透明
* @param activity
*/
@TargetApi(19)
public static void transparencyBar(Activity activity){if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {Window window = activity.getWindow();
window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
| View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
window.setStatusBarColor(Color.TRANSPARENT);
} else
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {Window window =activity.getWindow();
window.setFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS,
WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
}
}
/**
* 状态栏亮色模式,设置状态栏彩色文字、图标,* 适配 4.4 以上版本 MIUIV、Flyme 和 6.0 以上版本其余 Android
* @param activity
* @return 1:MIUUI 2:Flyme 3:android6.0
*/
public static int StatusBarLightMode(Activity activity){
int result=0;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
// 小米的亮度模式
if(MIUISetStatusBarLightMode(activity, true)){
result=1;
// 魅族的亮度模式
}else if(FlymeSetStatusBarLightMode(activity.getWindow(), true)){
result=2;
// 原生
}else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {activity.getWindow().getDecorView().setSystemUiVisibility( View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN|View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
result=3;
}
}
return result;
}
/**
* 已知零碎类型时,设置状态栏彩色文字、图标。* 适配 4.4 以上版本 MIUIV、Flyme 和 6.0 以上版本其余 Android
* @param activity
* @param type 1:MIUUI 2:Flyme 3:android6.0
*/
public static void StatusBarLightMode(Activity activity,int type){if(type==1){MIUISetStatusBarLightMode(activity, true);
}else if(type==2){FlymeSetStatusBarLightMode(activity.getWindow(), true);
}else if(type==3){activity.getWindow().getDecorView().setSystemUiVisibility( View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN|View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
}
}
/**
* 状态栏暗色模式,革除 MIUI、flyme 或 6.0 以上版本状态栏彩色文字、图标
*/
public static void StatusBarDarkMode(Activity activity,int type){if(type==1){MIUISetStatusBarLightMode(activity, false);
}else if(type==2){FlymeSetStatusBarLightMode(activity.getWindow(), false);
}else if(type==3){activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
}
}
/**
* 状态栏暗色模式,革除 MIUI、flyme 或 6.0 以上版本状态栏彩色文字、图标
*/
public static int StatusBarDarkMode(Activity activity){
int result=0;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
// 小米的亮度模式
if(MIUISetStatusBarLightMode(activity, false)){
result=1;
// 魅族的亮度模式
}else if(FlymeSetStatusBarLightMode(activity.getWindow(), false)){
result=2;
// 原生
}else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
result=3;
}
}
return result;
}
/**
* 设置状态栏图标为深色和魅族特定的文字格调
* 能够用来判断是否为 Flyme 用户
* @param window 须要设置的窗口
* @param dark 是否把状态栏文字及图标色彩设置为深色
* @return boolean 胜利执行返回 true
*
*/
public static boolean FlymeSetStatusBarLightMode(Window window, boolean dark) {
boolean result = false;
if (window != null) {
try {WindowManager.LayoutParams lp = window.getAttributes();
Field darkFlag = WindowManager.LayoutParams.class
.getDeclaredField("MEIZU_FLAG_DARK_STATUS_BAR_ICON");
Field meizuFlags = WindowManager.LayoutParams.class
.getDeclaredField("meizuFlags");
darkFlag.setAccessible(true);
meizuFlags.setAccessible(true);
int bit = darkFlag.getInt(null);
int value = meizuFlags.getInt(lp);
if (dark) {value |= bit;} else {value &= ~bit;}
meizuFlags.setInt(lp, value);
window.setAttributes(lp);
result = true;
} catch (Exception e) {}}
return result;
}
/**
* 须要 MIUIV6 以上
* @param activity
* @param dark 是否把状态栏文字及图标色彩设置为深色
* @return boolean 胜利执行返回 true
*
*/
public static boolean MIUISetStatusBarLightMode(Activity activity, boolean dark) {
boolean result = false;
Window window=activity.getWindow();
if (window != null) {Class clazz = window.getClass();
try {
int darkModeFlag = 0;
Class layoutParams = Class.forName("android.view.MiuiWindowManager$LayoutParams");
Field field = layoutParams.getField("EXTRA_FLAG_STATUS_BAR_DARK_MODE");
darkModeFlag = field.getInt(layoutParams);
Method extraFlagField = clazz.getMethod("setExtraFlags", int.class, int.class);
if(dark){extraFlagField.invoke(window,darkModeFlag,darkModeFlag);// 状态栏通明且彩色字体
}else{extraFlagField.invoke(window, 0, darkModeFlag);// 革除彩色字体
}
result=true;
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
// 开发版 7.7.13 及当前版本采纳了零碎 API,旧办法有效但不会报错,所以两个形式都要加上
if(dark){activity.getWindow().getDecorView().setSystemUiVisibility( View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN| View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
}else {activity.getWindow().getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_VISIBLE);
}
}
}catch (Exception e){}}
return result;
}
}
三:自定义标题栏 ToolBar
最根本的应用 background 设置背景色
<androidx.appcompat.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/green"/>
<androidx.appcompat.widget.Toolbar
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/green"
app:navigationIcon="@mipmap/ic_launcher"// 设置返回按钮
app:logo="@mipmap/ic_launcher"//logo 增加 logo
app:title="ToolBar 题目"//title 和 subtitle 增加题目和子标题
app:subtitle="ToolBar 子标题"
app:titleTextColor="#ffffff"//titleTextColor 和 subtitleTextColor 批改题目和子标题的色彩
app:subtitleTextColor="#ffffff"
app:collapseIcon="@mipmap/back"//collapseIcon 设置折叠视图的图标
>
</androidx.appcompat.widget.Toolbar>
toolBar 还能够增加菜单 Menu
通过 inflateMenu 能够增加 toolbar 的菜单
在 res 目录下新建文件夹 menu, 而后创立 toolbar_menu 文件
Toolbar toolbar=findViewById(R.id.toolbar);
toolbar.inflateMenu(R.menu.toolbar_menu);
toolbar_menu 的文件内容
<?xml version="1.0" encoding="utf-8"?>
<menu
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<item
android:id="@+id/action_search"
android:icon="@mipmap/ic_launcher"
android:title="按钮 1"
app:showAsAction="ifRoom" />
<item
android:id="@+id/action_notification"
android:icon="@mipmap/ic_launcher"
android:title="按钮 2"
app:showAsAction="ifRoom" />
<item
android:id="@+id/action_item_one"
android:title="按钮 3"
app:showAsAction="never" />
<item
android:id="@+id/action_item_two"
android:title="按钮 4"
app:showAsAction="never" />
</menu>
<!-- 每个菜单都能够设置特有的属性
orderInCategory
设置菜单项的排列程序,必须设置大于等于 0 的整数值。数值小的排列在前,如果值相等,则依照 xml 中的程序展示。title
菜单项的题目。icon
菜单项的图标。showAsAction
该属性有五个值,能够混合应用。always:总是显示在 Toolbar 上。ifRoom:如果 Toolbar 上还有空间,则显示,否则会暗藏在溢出列表中。never:永远不会显示在 Toolbar 上,只会在溢出列表中呈现。withText:文字和图标一起显示。collapseActionView:申明了这个操作视窗应该被折叠到一个按钮中,当用户抉择这个按钮时,这个操作视窗开展。个别要配合 ifRoom 一起应用才会无效。-->
END: 世界上那些最容易的事件中,拖延时间最不费劲