一、常用style属性
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!-- Customize your theme here. -->
<!--Appbar背景色-->
<item name="colorPrimary">@color/colorPrimary</item>
<!--状态栏颜色-->
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
<!--是否显示title,如果设置了windowActionBar = false则必须设置windowNoTitle = true,否则会报错-->
<item name="windowNoTitle">true</item>
<item name="windowActionBar">false</item>
<!--设置遮盖(activity启动时短暂展示的画面)-->
<item name="android:windowContentOverlay">@null</item>
<!--覆盖模式(需要手动设置布局的paddingTop或者marginTop,确保布局在actionbar的下方)-->
<item name="android:windowActionBarOverlay">true</item>
<!--Button正常状态下的颜色-->
<item name="colorButtonNormal">@color/colorAccent</item>
<!--控件文字的颜色(例如button)-->
<item name="android:textColorPrimary">@color/holo_orange_light</item>
<!--各个控制控件的默认颜色-->
<item name="colorControlNormal">@color/colorPrimary</item>
<!--控制各个控件被选中时的颜色-->
<item name="colorAccent">@color/colorAccent</item>
<!--控件点击波纹效果的颜色(适用于5.0以上)-->
<item name="colorControlHighlight">@color/btn_blue_normal</item>
<!--页面背景色-->
<item name="android:windowBackground">@color/holo_red_light</item>
</style>
二、Activity的显示模式
Android应用的状态的栏、导航栏给我们提供了很多搭配选择,虽然Material Design的设计很不错,但是这依旧磨灭不了UI设计爱折腾的开发的乐趣。通过修改显示模式我们可以根据UI设计的需求写出我们想要的样式。
全面屏的爆发让好多设备都去掉了物理按键,所以在NavigationBar的处理上一点要小心,否则发布的时候肯能会因为某些机型的不适配而被拒绝
有一点小问题,状态栏我们可以设置颜色,当UI提供的设计,整个状态栏和标题栏是一张背景图的时候,状态栏这里怎么处理比较合适?我现在的处理办法的是将状态栏设置成透明,然后在标题栏的上方放置一个高度为25dp的View来达到这个效果,不知道有没有其他更好的处理方式。
/**
* 应用全屏,状态栏透明,不隐藏底部导航栏
* SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN:Activity全屏显示,但状态栏不会被隐藏覆盖,状态栏依然可见,Activity顶端布局部分会被状态遮住
* SYSTEM_UI_FLAG_LAYOUT_STABLE:防止系统栏隐藏时内容区域大小发生变化
* FLAG_TRANSLUCENT_STATUS:透明状态栏
* FLAG_TRANSLUCENT_NAVIGATION:透明底部导航栏
* SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION:隐藏底部导航栏
* FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS:因系统版本诧异的原因需要设置FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS属性才可以设置setStatusBarColor
*/
protected void applyTheme() {
getWindow().requestFeature(Window.FEATURE_NO_TITLE);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
Window window = getWindow();
window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS
| WindowManager.LayoutParams.FLAG_TRANSLUCENT_NAVIGATION);
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);
window.setNavigationBarColor(Color.TRANSPARENT);
}
}