在Android 4.4以后,引入了Translucent System Bar的系特性,用于解決系統(tǒng)通知欄問題。

image.png

image.png
系統(tǒng)的通知欄和app界面融為一體,不再是孤立通知欄了。
但是這兩個是有點區(qū)別的下面細說。
具體操作 方法一
(系統(tǒng)狀態(tài)欄一般25dp)
主要修改的操作在 style.xml 文件中。
要在Activity中使用 Translucent System Bar 特性,首先需要到AndroidManifest中為指定的Activity設(shè)置Theme, 注意 不能直接在values/style.xml直接去自定義 Translucet System Bar 的Theme,因為特性具有SDK版本 的限制,所以要分別創(chuàng)建values、values-v19/style.xml、values-v21/style.xml文件然后就可以操作了。在對應SDK版本中定制對應的樣式了。
在Android 4.4之前的版本上運行,直接跟隨系統(tǒng)主題
<style name="StatusTheme" parent="AppTheme">
</style>
- 在Android 4.4 版本上運行 values-v19/style.xml
<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
<item name="android:windowTranslucentStatus">false</item>
<!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
<item name="android:windowTranslucentNavigation">false</item>
</style>
- 在Android 5.0 版本及以上上運行 values-v21/style.xml
<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
<item name="android:windowTranslucentStatus">false</item>
<!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
<item name="android:windowTranslucentNavigation">false</item>
<!--Android 5.x開始需要把顏色設(shè)置透明,否則導航欄會呈現(xiàn)系統(tǒng)默認的淺灰色-->
<item name="android:statusBarColor">@android:color/transparent</item>
</style>
注意,這三個文件中的values/style.mxl對應的主題theme名稱要相同。
第一個圖片樣式
在AndroidManifest.xml中對指定Activity的theme樣式
并在此activity的根布局中加入:
android:fitsSystemWindows="true"
把背景替換為要演示的圖片即可
第二種圖片樣式
Tab欄和系統(tǒng)導航欄分開來設(shè)置。
<style name="StatusTheme" parent="Theme.AppCompat.Light.DarkActionBar">
<!--設(shè)置為true這狀態(tài)欄會變成深灰色-->
<item name="android:windowTranslucentStatus">false</item>
<!--設(shè)置為只有在上面的設(shè)置為true時 此true 下面會顯示一個系統(tǒng)狀態(tài)欄同上面-->
<item name="android:windowTranslucentNavigation">false</item>
<!--Android 5.x開始需要把顏色設(shè)置透明,否則導航欄會呈現(xiàn)系統(tǒng)默認的淺灰色-->
<item name="android:statusBarColor">@android:color/transparent</item>
</style>
方法二 代碼方式實現(xiàn)
通過代碼獲取系統(tǒng)狀態(tài)欄并對其修改
public class TestActivity extends AppCompatActivity {
//在Activity的setContentView后進行修改系統(tǒng)狀態(tài)欄
@Override
public void setContentView(int layoutResID) {
super.setContentView(layoutResID);
setStatusBar();
}
// 為狀態(tài)欄添加默認樣式
protected void setStatusBar(int color, int statusBarAlpha) {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) { // 版本號大于5.0
getWindow().addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
getWindow().clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
getWindow().setStatusBarColor(calculateStatusColor(color, statusBarAlpha));
} else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) { // 版本號大于4.4
getWindow().addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
ViewGroup decorView = (ViewGroup) getWindow().getDecorView();
View fakeStatusBarView = decorView.findViewById(FAKE_STATUS_BAR_VIEW_ID);
if (fakeStatusBarView != null) {
if (fakeStatusBarView.getVisibility() == View.GONE) {
fakeStatusBarView.setVisibility(View.VISIBLE);
}
fakeStatusBarView.setBackgroundColor(calculateStatusColor(color, statusBarAlpha));
} else {
decorView.addView(createStatusBarView(this, color, statusBarAlpha));
}
setRootView(this);
}
}
/**
* 生成一個和狀態(tài)欄大小相同的半透明矩形條
* @param activity 需要設(shè)置的activity
* @param color 狀態(tài)欄顏色值
* @param alpha 透明值
* @return 狀態(tài)欄矩形條
*/
private static View createStatusBarView(@ColorInt int color, int alpha) {
// 獲得狀態(tài)欄高度
int resourceId = getResources().getIdentifier("status_bar_height", "dimen", "android");
// 繪制一個和狀態(tài)欄一樣高的矩形
View statusBarView = new View(this);
LinearLayout.LayoutParams params =
new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, getResources().getDimensionPixelSize(resourceId));
statusBarView.setLayoutParams(params);
statusBarView.setBackgroundColor(calculateStatusColor(color, alpha));
statusBarView.setId(FAKE_STATUS_BAR_VIEW_ID);
return statusBarView;
}
// 設(shè)置根布局參數(shù)
private static void setRootView() {
ViewGroup parent = (ViewGroup) findViewById(android.R.id.content);
for (int i = 0, count = parent.getChildCount(); i < count; i++) {
View childView = parent.getChildAt(i);
if (childView instanceof ViewGroup) {
childView.setFitsSystemWindows(true);
((ViewGroup) childView).setClipToPadding(true);
}
}
}
/**
* 計算狀態(tài)欄顏色
* @param color color值
* @param alpha alpha值
* @return 最終的狀態(tài)欄顏色
*/
private static int calculateStatusColor(@ColorInt int color, int alpha) {
if (alpha == 0) {
return color;
}
float a = 1 - alpha / 255f;
int red = color >> 16 & 0xff;
int green = color >> 8 & 0xff;
int blue = color & 0xff;
red = (int) (red * a + 0.5);
green = (int) (green * a + 0.5);
blue = (int) (blue * a + 0.5);
return 0xff << 24 | red << 16 | green << 8 | blue;
}
}
首先在一個BaseActivity中做些工作