关于沉浸式状态栏说法一般持有2种观念:
1.设置statusbar并不是真正的沉浸式,所谓的沉浸式应该不带一丝杂质
实现过程:
@Override
public void onWindowFocusChanged(boolean hasFocus) {
super.onWindowFocusChanged(hasFocus);
if (hasFocus && Build.VERSION.SDK_INT >= 19) {
View decorView = getWindow().getDecorView();
decorView.setSystemUiVisibility(
View.SYSTEM_UI_FLAG_LAYOUT_STABLE
| View.SYSTEM_UI_FLAG_LAYOUT_HIDE_NAVIGATION
| View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN
| View.SYSTEM_UI_FLAG_HIDE_NAVIGATION
| View.SYSTEM_UI_FLAG_FULLSCREEN
| View.SYSTEM_UI_FLAG_IMMERSIVE_STICKY);
}
}
你想显示statusbar和底部导航只需要在边缘滑动就会出来;
2.使用设置状态栏透明,但这样你所设置的toolbar会向上占位,所以我们获取状态栏的高度如下 :
public static int getStatusBarHeight(Context context) {
int result = 0;
int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
if (resourceId > 0) {
result = context.getResources().getDimensionPixelSize(resourceId);
}
return result;
}
4.4版本和5.0以上版本的设置方法不同所以我们要做适配方法如下:
public static void compat(Activity activity, int statusColor) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
if (statusColor != INVALID_VAL) {
activity.getWindow().setStatusBarColor(statusColor);
}
return;
}
// KITKAT 4.4 LOLLIPOP 5.0
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT && Build.VERSION.SDK_INT < Build.VERSION_CODES.LOLLIPOP) {
int color = COLOR_DEFAULT;
ViewGroup contentView = (ViewGroup) activity.findViewById(android.R.id.content);
if (statusColor != INVALID_VAL) {
color = statusColor;
}
View statusBarView = new View(activity);
ViewGroup.LayoutParams lp = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,
getStatusBarHeight(activity));
statusBarView.setBackgroundColor(color);
contentView.addView(statusBarView, lp);
}
}
如果是5.0以上就直接设置statusBar的颜色,如果是在4.4与5.0直接就需要创建一个view高度为获取的状态栏高度进行占位,不然就挤到一起去了;
踩坑提示:1.因为是要占位所以你的toolbar 如果是通过include它的父布局一定要是LinearLayout ,并且设置
height为wrapcontent ,并添加属性android:fitsSystemWindows=”true”
2.要在setContentView后在调用compat(Activity ,int statusColor ) 方法;
接着就是这种状态栏为透明了,代码设置或创建一个values-19,values-21都可以
values-19
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="@style/BaseAppTheme">
<item name="android:windowTranslucentStatus">true</item>
</style>
</resources>
values-21
<resources>
<!-- Base application theme. -->
<style name="AppTheme" parent="@style/BaseAppTheme">
</style>
</resources>
以上2种方法都讲完了,根据项目的需要可以选择不同的方式;