沉浸式狀態(tài)欄工具

/**
 * Created by ricky.peng on 2018/5/25.
 * @author ricky.peng
 * 沉浸式狀態(tài)欄工具類
 */
public class TStatusBarHelper {
    //是否需要沉浸式狀態(tài)欄
    private static boolean isNeedTransStatus=true;
    //沉浸式狀態(tài)欄公荧,比較復(fù)雜的沉浸式建議用這個
    // 4.4上沒有狀態(tài)欄著色,如果狀態(tài)欄變淺色容易導(dǎo)致看不清狀態(tài)欄字體残邀,
    // 5.0有著色的時候,避免淺色狀態(tài)欄看不清字體設(shè)置半透明狀態(tài)欄
    // 6.0 SYSTEM_UI_FLAG_LIGHT_STATUS_BAR可以讓系統(tǒng)自適應(yīng)狀態(tài)欄字體和背景色
    public static void translucentStatus(Activity activity) {
        if (activity == null||!isNeedTransStatus) {
            return;
        }
        Window window = activity.getWindow();
        if (window != null) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                //取消狀態(tài)欄透明
                window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
                //添加Flag把狀態(tài)欄設(shè)為可繪制模式
                window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
                //設(shè)置狀態(tài)欄顏色,API 21開始可以使用洲脂,低于6.0的時候掏湾,很多頁面都是淺色的,導(dǎo)致狀態(tài)欄不清晰飞盆,所以5.0設(shè)置半透明
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    window.setStatusBarColor(Color.TRANSPARENT);
                } else if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                    window.setStatusBarColor(Color.parseColor("#33000000"));
                }
                //設(shè)置系統(tǒng)狀態(tài)欄處于可見狀態(tài)
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
                } else {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
                }
            }
        }
    }
    //沉浸式狀態(tài)欄娄琉,如果UI設(shè)計比較簡單,建議使用這個
    public static void translucentEasyStatus(Activity activity) {
        if (activity == null||!isNeedTransStatus) {
            return;
        }
        Window window = activity.getWindow();
        if (window != null) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
                window.addFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
            }
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                //取消狀態(tài)欄透明
                window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
                //添加Flag把狀態(tài)欄設(shè)為可繪制模式
                window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
                //設(shè)置狀態(tài)欄顏色,API 21開始可以使用吓歇,低于6.0的時候孽水,很多頁面都是淺色的,導(dǎo)致狀態(tài)欄不清晰城看,所以5.0設(shè)置半透明
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    window.setStatusBarColor(Color.TRANSPARENT);
                }
                //設(shè)置系統(tǒng)狀態(tài)欄處于可見狀態(tài)
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
                } else {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
                }
            }
        }
    }
    //沉浸式狀態(tài)欄女气,微信的做法,通過UI設(shè)計同意toolbar和狀態(tài)欄顏色析命,減少適配的問題
    public static void translucentStatus(Activity activity,int color) {
        if (activity == null||!isNeedTransStatus) {
            return;
        }
        Window window = activity.getWindow();
        if (window != null) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                //取消狀態(tài)欄透明
                window.clearFlags(WindowManager.LayoutParams.FLAG_TRANSLUCENT_STATUS);
                //添加Flag把狀態(tài)欄設(shè)為可繪制模式
                window.addFlags(WindowManager.LayoutParams.FLAG_DRAWS_SYSTEM_BAR_BACKGROUNDS);
                //設(shè)置狀態(tài)欄顏色
                window.setStatusBarColor(ContextCompat.getColor(activity, color));
                //設(shè)置系統(tǒng)狀態(tài)欄處于可見狀態(tài)
                if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LIGHT_STATUS_BAR);
                } else {
                    window.getDecorView().setSystemUiVisibility(View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_LAYOUT_STABLE);
                }
            }
        }
    }
    //fragment的沉浸式適配主卫,要讓fragment的背景延伸到狀態(tài)欄
    // 不使用activity的背景色的時候,fitSystemWindows=false,然后再fragment中設(shè)置這個,否則直接設(shè)置fitSystemWindows=true會采用activity的背景色
    public static void setStatusBarHeight(View view){
        if (view!=null&&isNeedTransStatus) {
            if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
                view.setPadding(0, getstatubarheight(view.getContext()), 0, 0);
            }
        }
    }
    //獲取狀態(tài)欄高度
    private static int getstatubarheight(Context context) {
        int height = 0;
        int resourceid = context.getResources().getIdentifier("status_bar_height", "dimen", "android");
        if (resourceid > 0) {
            height = context.getResources().getDimensionPixelOffset(resourceid);
        }
        return height;
    }
}

想要做到包括圖片在內(nèi)的沉浸, 必須理解好fitsSystemWindows屬性, 以利用padding效果, 將內(nèi)容上移或者下移
當(dāng)然鹃愤,還有xml的方法可以設(shè)置簇搅,百度谷歌都有很多,還有設(shè)置沉浸以后在頂部設(shè)置一個透明view的方法软吐。
大家具體可以根據(jù)項目需求瘩将,選擇最簡單的實現(xiàn)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末凹耙,一起剝皮案震驚了整個濱河市姿现,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌肖抱,老刑警劉巖备典,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異意述,居然都是意外死亡提佣,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門荤崇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拌屏,“玉大人,你說我怎么就攤上這事术荤∫形梗” “怎么了?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵瓣戚,是天一觀的道長端圈。 經(jīng)常有香客問我焦读,道長,這世上最難降的妖魔是什么舱权? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任吨灭,我火速辦了婚禮,結(jié)果婚禮上刑巧,老公的妹妹穿的比我還像新娘。我一直安慰自己无畔,他們只是感情好啊楚,可當(dāng)我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著浑彰,像睡著了一般恭理。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上郭变,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天颜价,我揣著相機與錄音,去河邊找鬼诉濒。 笑死周伦,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的未荒。 我是一名探鬼主播专挪,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼片排!你這毒婦竟也來了寨腔?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤率寡,失蹤者是張志新(化名)和其女友劉穎迫卢,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體冶共,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡乾蛤,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了比默。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片幻捏。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖命咐,靈堂內(nèi)的尸體忽然破棺而出篡九,到底是詐尸還是另有隱情,我是刑警寧澤醋奠,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布榛臼,位于F島的核電站伊佃,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏沛善。R本人自食惡果不足惜航揉,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望金刁。 院中可真熱鬧帅涂,春花似錦、人聲如沸尤蛮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽产捞。三九已至醇锚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間坯临,已是汗流浹背焊唬。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留看靠,地道東北人赶促。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像挟炬,于是被迫代替她去往敵國和親芳杏。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,876評論 2 361