iOS開發(fā)技巧之狀態(tài)欄字體顏色的設置方法
狀態(tài)欄的字體為黑色:UIStatusBarStyleDefault
狀態(tài)欄的字體為白色:UIStatusBarStyleLightContent
一、在info.plist中,將View controller-based status bar appearance設為NO
狀態(tài)欄字體的顏色只由下面的屬性設定,默認為白色:
// default is UIStatusBarStyleDefault [UIApplication sharedApplication].statusBarStyle
解決個別vc中狀態(tài)欄字體顏色不同的辦法
1、在info.plist中,將View controller-based status bar appearance設為NO.
2、在app delegate中:
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
3、在個別狀態(tài)欄字體顏色不一樣的vc中
-(void)viewWillAppear:(BOOL)animated{
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
}
-(void)viewWillDisappear:(BOOL)animated
{
[super viewWillDisappear:animated];
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
}
二、在info.plist中,將View controller-based status bar appearance設為YES,或者沒有設置。
View controller-based status bar appearance的默認值就是YES。
如果View controller-based status bar appearance為YES。
則[UIApplication sharedApplication].statusBarStyle 無效。
用下面的方法:
1、在vc中重寫vc的preferredStatusBarStyle方法。
-(UIStatusBarStyle)preferredStatusBarStyle
{
return UIStatusBarStyleDefault;
}
2、在viewDidload中調(diào)用: [self setNeedsStatusBarAppearanceUpdate];
但是,當vc在nav中時,上面方法沒用,vc中的preferredStatusBarStyle方法根本不用被調(diào)用。
原因是, [self setNeedsStatusBarAppearanceUpdate]發(fā)出后,
只會調(diào)用navigation controller中的preferredStatusBarStyle方法,
vc中的preferredStatusBarStyley方法跟本不會被調(diào)用。
解決辦法有兩個:
方法一:
設置navbar的barStyle 屬性會影響status bar 的字體和背景色。如下。
//status bar的字體為白色 //導航欄的背景色是黑色。 self.navigationController.navigationBar.barStyle = UIBarStyleBlack; //status bar的字體為黑色 //導航欄的背景色是白色,狀態(tài)欄的背景色也是白色。 //self.navigationController.navigationBar.barStyle = UIBarStyleDefault;
方法二:
自定義一個nav bar的子類,在這個子類中重寫preferredStatusBarStyle方法:
MyNav* nav = [[MyNav alloc] initWithRootViewController:vc];
self.window.rootViewController = nav;
@implementation MyNav
- (UIStatusBarStyle)preferredStatusBarStyle
{
UIViewController* topVC = self.topViewController;
return [topVC preferredStatusBarStyle];
}
附:修改狀態(tài)欄的背景顏色 (牽扯到UIWindow的層級關系)
/*改變狀態(tài)欄的背景顏色,因為狀態(tài)欄的層級比較高,所以按照如下添加就可以出來效果*/ UIView* stateView = [[UIView alloc] initWithFrame:CGRectMake(0, -20, SCREEN_WIDTH, 20)]; [self.navigationController.navigationBar addSubview:stateView]; stateView.backgroundColor = [UIColor purpleColor];
備注: 因為在OC中,都應該知道UIWindow有三個層級,如下:
UIKIT_EXTERN const UIWindowLevel UIWindowLevelNormal;
UIKIT_EXTERN const UIWindowLevel UIWindowLevelAlert;
UIKIT_EXTERN const UIWindowLevel UIWindowLevelStatusBar
它們層級的優(yōu)先級的值分別對應的是:
UIWindowLevelNormal: 0
UIWindowLevelAlert: 1000
UIWindowLevelStatusBar:2000
(而且UIAlertView的層級優(yōu)先級為1996,UIActionSheet的層級優(yōu)先級為2001)
優(yōu)先級
總結:
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
ios的手勢操作之UIGestureRecognizer淺析(推薦)
本篇文章主要介紹了ios的手勢操作之UIGestureRecognizer淺析,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。2016-12-12
iOS開發(fā)之(APNS)遠程推送實現(xiàn)代碼 附證書與真機調(diào)試
這篇文章主要為大家詳細介紹了iOS開發(fā)之(APNS)遠程推送實現(xiàn)代碼,附證書與真機調(diào)試,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09

