在Google Material Design 中介绍了3种不同的status bar的风格:
- 黑色背景的status bar
- 能够改变status bar的颜色
- 透明的status bar
A、经典的状态栏
B、有颜色的状态栏
C、透明的状态栏
改变状态栏的颜色:
如果Toolbar 的颜色为500
那么根据Material Design 的建议我的状态栏颜色应该为
Android5.0以上和使用Material Design 只需要设置Style(v21) XML的属性即可:
<!-- Toolbar的颜色 -->
<item name="colorPrimary">@color/primary</item>
<!-- Status bar的颜色 -->
<item name="colorPrimaryDark">@color/primary_dark</item>
<!--Status bar的颜色 -->
<item name="statusBarColor">@color/primary_dark</item>
让状态栏透明:
1、在Styles.xml and Styles(v21).xml中实现
<!-- Make the status bar traslucent <span style="color: rgb(84, 84, 84); font-family: arial, sans-serif;font-size:12px; line-height: 18.2px;">将填充顶部的状态栏区域</span>-->
<style name="AppTheme" parent="AppTheme.Base">
<item name="android:windowTranslucentStatus">true</item>
</style>
2.通过下列方法获取状态栏的高度(因为不同设备的高度不一样)
// A method to find height of the status bar in activity
public int getStatusBarHeight() {
int result = 0;
int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");
if (resourceId > 0) {
result = getResources().getDimensionPixelSize(resourceId);
}
return result;
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_drawer);
// Retrieve the AppCompact Toolbar
Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar);
// Set the padding to match the Status Bar height 可以换成任何View组件
toolbar.setPadding(0, getStatusBarHeight(), 0, 0);
}
透明状态栏简单方法2:
只需要在styles的AppTheme中加入:
<item name="android:windowTranslucentStatus">true</item>
或在欧尼oncreate中加入getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
就可以实现透明状态栏,而在原生上则是半透明的。
你的 actionBar 会上挪到屏幕顶部,修正的方法是在布局 xml 的 root 节点里加入:
android:fitsSystemWindows="true"
使得控件增加一部分填充到状态栏