ios開(kāi)發(fā) 改變狀態(tài)欄的樣式、顏色、自定義

狀態(tài)欄的字體為黑色背景為白色:UIStatusBarStyleDefault
狀態(tài)欄的字體為白色背景為黑色:UIStatusBarStyleLightContent

一、在info.plist中,將View controller-based status bar appearance設(shè)為YES,或者沒(méi)有設(shè)置。
View controller-based status bar appearance的默認(rèn)值就是YES。
如果View controller-based status bar appearance為YES。
則[UIApplication sharedApplication].statusBarStyle 無(wú)效。

用下面的方法:

1、在vc中重寫(xiě)vc的preferredStatusBarStyle方法。

-(UIStatusBarStyle)preferredStatusBarStyle

{

return UIStatusBarStyleDefault;

}

2、在viewDidload中調(diào)用:[self setNeedsStatusBarAppearanceUpdate];

但是,當(dāng)vc在nav中時(shí),上面方法沒(méi)用,vc中的preferredStatusBarStyle方法根本不用被調(diào)用。

原因是,[self setNeedsStatusBarAppearanceUpdate]發(fā)出后,

只會(huì)調(diào)用navigation controller中的preferredStatusBarStyle方法,

vc中的preferredStatusBarStyley方法跟本不會(huì)被調(diào)用。

解決辦法有兩個(gè):

方法一:

設(shè)置navbar的barStyle 屬性會(huì)影響status bar 的字體和背景色。如下。

//status bar的字體為白色

//導(dǎo)航欄的背景色是黑色。

self.navigationController.navigationBar.barStyle = UIBarStyleBlack;

//status bar的字體為黑色

//導(dǎo)航欄的背景色是白色,狀態(tài)欄的背景色也是白色。

//self.navigationController.navigationBar.barStyle = UIBarStyleDefault;

方法二:

自定義一個(gè)nav bar的子類(lèi),在這個(gè)子類(lèi)中重寫(xiě)preferredStatusBarStyle方法:

MyNav* nav = [[MyNav alloc] initWithRootViewController:vc];

self.window.rootViewController = nav;

@implementation MyNav

- (UIStatusBarStyle)preferredStatusBarStyle

{

UIViewController* topVC = self.topViewController;

return [topVC preferredStatusBarStyle];

}

二、在info.plist中,將View controller-based status bar appearance設(shè)為NO

狀態(tài)欄字體的顏色只由下面的屬性設(shè)定,默認(rèn)為白色:

// default is UIStatusBarStyleDefault

[UIApplication sharedApplication].statusBarStyle

解決個(gè)別vc中狀態(tài)欄字體顏色不同的辦法

1、在info.plist中,將View controller-based status bar appearance設(shè)為NO.

2、在app delegate中:

[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

3、在個(gè)別狀態(tài)欄字體顏色不一樣的vc中

-(void)viewWillAppear:(BOOL)animated{

[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;

}

-(void)viewWillDisappear:(BOOL)animated

{

[super viewWillDisappear:animated];

[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

}

三、修改狀態(tài)欄的背景顏色 (牽扯到UIWindow的層級(jí)關(guān)系)

/*改變狀態(tài)欄的背景顏色,因?yàn)闋顟B(tài)欄的層級(jí)比較高,所以按照如下添加就可以出來(lái)效果*/
UIView* stateView = [[UIView alloc] initWithFrame:CGRectMake(0, -20, SCREEN_WIDTH, 20)];
[self.navigationController.navigationBar addSubview:stateView];stateView.backgroundColor = [UIColor purpleColor];

備注: 因?yàn)樵贠C中,都應(yīng)該知道UIWindow有三個(gè)層級(jí),如下:

UIKIT_EXTERN const UIWindowLevel 
UIWindowLevelNormal;UIKIT_EXTERN const UIWindowLevel 
UIWindowLevelAlert;UIKIT_EXTERN const UIWindowLevel 
UIWindowLevelStatusBar
它們層級(jí)的優(yōu)先級(jí)的值分別對(duì)應(yīng)的是:
UIWindowLevelNormal: 0
UIWindowLevelAlert: 1000
UIWindowLevelStatusBar:2000
(而且UIAlertView的層級(jí)優(yōu)先級(jí)為1996,UIActionSheet的層級(jí)優(yōu)先級(jí)為2001)優(yōu)先級(jí)

4 自定義狀態(tài)欄
如果說(shuō)自定義的狀態(tài)欄,想直接把狀態(tài)欄上的文字,時(shí)間,電量的標(biāo)記全部遮擋住,可以自定義一個(gè)UIView,然后將這個(gè)UIView添加到UIWindow上,如下所示:

UIWindow* backWindow = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];
backWindow.windowLevel = UIWindowLevelStatusBar + 1; //層級(jí)略高于UIWindowLevelStatusBar
[backWindow becomeKeyWindow];
[backWindow makeKeyAndVisible];
[backWindow addSubview:self];

如果在操作過(guò)層中,出現(xiàn)差異,請(qǐng)閱讀資料,謹(jǐn)慎處理

備注:如果按照如上步驟修改info.plist之后,仍然沒(méi)有效果,可以嘗試重啟Xcode...或者嘗試刪除Xcode的緩存文件,步驟如下圖所示:1) 啟動(dòng)Xcode,點(diǎn)擊command + '逗號(hào)'鍵2) 如下圖:

步驟一.png
  1. 點(diǎn)擊進(jìn)去之后,選擇‘DerivedData’文件目錄,之后雙擊進(jìn)去,全部刪除即可(之后也可以再次點(diǎn)擊Product -- >Clean)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容