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:世界上那些最容易的事件中,拖延时间最不费劲