狀態(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) 如下圖:

- 點(diǎn)擊進(jìn)去之后,選擇‘DerivedData’文件目錄,之后雙擊進(jìn)去,全部刪除即可(之后也可以再次點(diǎn)擊Product -- >Clean)