Android 狀態(tài)欄的設置適配問題詳解
最近看了很多關于狀態(tài)欄的問題的處理,總結出處理狀態(tài)欄分兩個方向1>5.0一下2>5.0以上的手機狀態(tài)欄的設置,,,,,,,,這里說的都是自定義的toolbar,我這里已經(jīng)把titlebar給隱藏掉了
(1) 關于5.0一下:首先我們需要在res文件下的style中設置,
<!-- Base application theme. --><style name="AppTheme" parent="AppTheme.Base"> <!-- Customize your theme here. --></style><style name="AppTheme.Base" parent="Theme.AppCompat.Light.NoActionBar"> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> <item name="android:windowBackground">@android:color/white</item> <item name="android:windowNoTitle">true</item></style>
這里我為什么設置AppTheme.Base 而不直接用AppTheme,因為我繼承的是AppCompatActivity,如果直接對titlebar進行隱藏的話不做這個base處理,程序會報錯,,,,,,如果你繼承的是Activity的話那不會報錯 ,,,,為了處理 版本的更高適配,,,,就必須繼承 AppCompatActivity ,,,所以在適配5.0一下的系統(tǒng)的時候,就要做一個 base 來過渡 加載 style...
5.0一下的到此就結束了....
(2) 關于5.0以上的版本,,我門要在res下方增加一個 values-21文件,結構如圖

置于style中的代碼:如下
<style name="AppTheme.NoActionBar"> <item name="windowActionBar">false</item> <item name="windowNoTitle">true</item> <item name="android:windowDrawsSystemBarBackgrounds">true</item> <item name="android:statusBarColor">@android:color/transparent</item></style><style name="AppTheme" parent="Theme.AppCompat.Light.NoActionBar"> <item name="colorPrimary">@color/colorPrimary</item> <item name="colorPrimaryDark">@color/colorPrimaryDark</item> <item name="colorAccent">@color/colorAccent</item> <item name="android:windowDrawsSystemBarBackgrounds">true</item> <!-- 標題顏色 --> <item name="android:textColorPrimary">#000</item> <!-- 溢出菜單圖標顏色 --> <item name="colorControlNormal">@color/white</item> <!-- 箭頭 --> <item name="drawerArrowStyle">@style/DrawerArrowStyle</item> <!-- 溢出菜單文字顏色 --> <item name="textAppearanceLargePopupMenu">@style/OverflowMenuTextAppearance</item> <!-- 菜單項點擊selector --> <item name="actionBarItemBackground">@drawable/abc_item_background_holo_dark</item></style><!-- 左邊的箭頭指示 --><style name="DrawerArrowStyle" parent="Widget.AppCompat.DrawerArrowToggle"> <item name="spinBars">true</item> <item name="color">@color/white</item></style><!-- 溢出菜單文字樣式 --><style name="OverflowMenuTextAppearance" parent="@style/TextAppearance.AppCompat.Widget.PopupMenu.Large"> <item name="android:textColor">@color/white</item></style>
手機會 根據(jù) 你手機的系統(tǒng)版本去加載,這兩個style,5.x以上的 加載第二個 ,針對 不同的系統(tǒng)版本修改對應的style..........
當然 這兩步足夠做適配的了,但是 我們 可能需要進入不同界面 顯示不通的狀態(tài)欄,,,這時候 就要我們用代碼控制,修改了,,,,代碼 我也直接貼出來 ,,,一下 代碼 是 看別人的.......
(1) 在activity設置 這些,,,
int color = getResources().getColor(R.color.red);// View view = LayoutInflater.from(this).inflate(R.layout.statusbar,null); StatusBarManager statusBarManager = new StatusBarManager(this,color); //這里如果要移動titlebar,則在布局中指定為include的自定義statusbar的view //如果不指定,則調(diào)用setStatusBarView();會自動加一個view// statusBarManager.setStatusBarView(view); statusBarManager.setStatusBarView();
(2)重寫 一個類StatusBarManager 進行修改 :
package com.example.administrator.statusbartest;import android.annotation.TargetApi;import android.app.Activity;import android.content.Context;import android.graphics.Color;import android.os.Build;import android.view.View;import android.view.ViewGroup;import android.view.Window;import android.widget.FrameLayout;import android.widget.LinearLayout;import java.lang.reflect.Method;/** * Created by Administrator on 2017/3/21. */public class StatusBarManager { private static final int BUILD_VERSION_KITKAT = 19; private static final int BUILD_VERSION_LOLLIPOP = 21; //WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS public static final int FLAG_TRANSLUCENT_STATUS = 0x04000000; //WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS public static final int FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS = 0x80000000; private Activity mActivity; private View statusBarView; private int statusBarHeight; //設置狀態(tài)藍的顏色值 int color; public StatusBarManager(Activity activity,int color) { this.mActivity = activity; this.color = color; statusBarHeight = getStatusBarHeight(activity); } public void setStatusBarView(View statusBarView) { this.statusBarView = statusBarView; setTransparent(); } public void setStatusBarView() { setTransparent(); } public int getStatusBarHeight() { return statusBarHeight; } /** * 設置狀態(tài)欄全透明 * */ private void setTransparent() { //4.0沒有轉太爛 if (Build.VERSION.SDK_INT < BUILD_VERSION_KITKAT) { return; } if(statusBarHeight <= 0){ return; } transparentStatusBar(); showStatusBarView(); } @TargetApi(19) private void showStatusBarView() { /** * 設置狀態(tài)欄顏色的位置 */ if(statusBarView == null){ statusBarView = new View(mActivity); LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, getStatusBarHeight(mActivity)); statusBarView.setLayoutParams(params); statusBarView.setBackgroundColor(color); ViewGroup decorView = (ViewGroup) mActivity.getWindow().getDecorView(); FrameLayout content = (FrameLayout) decorView.findViewById(android.R.id.content); FrameLayout.LayoutParams layoutParams = (FrameLayout.LayoutParams) content.getChildAt(0).getLayoutParams(); layoutParams.setMargins(0,statusBarHeight,0,0); decorView.addView(statusBarView); }else{ ViewGroup.LayoutParams layoutParams = statusBarView.getLayoutParams(); layoutParams.height = getStatusBarHeight(mActivity); statusBarView.setLayoutParams(layoutParams); statusBarView.setBackgroundColor(color); } } /** * 參考上面注釋掉的代碼 因為需要用隱藏API 調(diào)用方式進行改成反射 */ private void transparentStatusBar(){ Window window = mActivity.getWindow(); if (Build.VERSION.SDK_INT >= BUILD_VERSION_LOLLIPOP) { //不add此條flag 會導致在EMUI3.1(華為)上失效,add這個flag 會導致在其它機型上面添加一個半透明黑條 window.addFlags(FLAG_TRANSLUCENT_STATUS); //下面的代碼段是不加上面的flag時,要顯示純色的狀態(tài)欄時需要加的代碼 不用了/* window.clearFlags(FLAG_TRANSLUCENT_STATUS); window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE); window.addFlags(FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);*/ //因為需要用隱藏API,沒有重新編譯5.x版本的android.jar,使用的還是18的api,這里用的反射 try { Class[] argsClass=new Class[]{int.class}; Method setStatusBarColorMethod = Window.class.getMethod("setStatusBarColor",argsClass); setStatusBarColorMethod.invoke(window, Color.TRANSPARENT); } catch (Exception e) { e.printStackTrace(); } }else{ window.addFlags(FLAG_TRANSLUCENT_STATUS); } } /** * 獲取狀態(tài)欄高度 * * @param context context * @return 狀態(tài)欄高度 */ private static int getStatusBarHeight(Context context) { if (Build.VERSION.SDK_INT < BUILD_VERSION_KITKAT) { return 0; } // 獲得狀態(tài)欄高度 int resourceId = context.getResources().getIdentifier("status_bar_height", "dimen", "android"); return context.getResources().getDimensionPixelSize(resourceId); } public void setStatusbarVisibility(int visibility){ if(statusBarView != null) { this.statusBarView.setVisibility(visibility); } } public void setColor(int color){ if(statusBarView != null){ this.statusBarView.setBackgroundColor(color); } }}做了這些就可以自定義你的狀態(tài)欄了,,,
新聞熱點
疑難解答
圖片精選