前言
//Setting statusBarHidden does nothing if your application is using the default UIViewController-based status bar system.
解读:“如果你的应用用的是系统默认的基于UIViewController的状态栏控制系统,那么statusBarHidden设置无效。”
@property(readwrite, nonatomic,getter=isStatusBarHidden) BOOL statusBarHidden NS_DEPRECATED_IOS(2_0, 9_0, "Use -[UIViewController prefersStatusBarHidden]") __TVOS_PROHIBITED;
// Setting the statusBarStyle does nothing if your application is using the default UIViewController-based status bar system.
解读:“如果你的应用用的是系统默认的基于UIViewController的状态栏控制系统,那么statusBarStyle设置无效。
@property(readwrite, nonatomic) UIStatusBarStyle statusBarStyle NS_DEPRECATED_IOS(2_0, 9_0, "Use -[UIViewController preferredStatusBarStyle]") __TVOS_PROHIBITED;
综上:
(1)当应用使用的是基于UIViewController的状态栏控制系统时,statusBarHidden/statusBarStyle设置都是无效的!
(2)可惜的是,UIViewController的状态栏控制系统是APP默认使用的,也即该系统下,以上两项设置无效。
那如何设置才能不使用该系统呢?
是否使用基于UIViewController的状态栏控制系统,可以在Info.plist中设置:在Info.plist中添加key为View controller-based status bar appearance的字典,value默认为YES,即默认使用该系统;不想使用的话设置为NO即可。
(一)当View controller-based status bar appearance条目value为NO时:
(1)全局设置:
A:配置项目或Info.plist设置(两者一样)
依次进入【Targets】->【General】->【Deployment Info】,然后可进行进行设置如下:
B:代码控制
a:能实现效果,但已弃用,有警告
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
[[UIApplication sharedApplication] setStatusBarHidden:YES];
b:新方法,建议使用,无警告
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
注意:使用代码控制全局的状态栏,代码的位置很重要;在AppDelegate中写入可以设置整个App页面的状态栏样式;
(2)局部设置:
A:当前ViewController不在导航上时:
a:重写UIViewController的两个get方法
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
结论:更改无效(❎)
b:利用UIApplication单例局部设置
- (void)viewWillAppear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
}
- (void)viewDidDisappear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
[UIApplication sharedApplication].statusBarHidden = NO;
}
结论:更改有效(✅)
注意:如果需要单独设置其中一个页面隐藏状态栏,需要在进入页面时设置隐藏,退出页面时设置显示,以保证不影响其他页面的状态栏样式。
B:当前ViewController在导航上时:
结论同上
C:当前ViewController是被导航上控制器push出来的:
结论同上
D:当前ViewController是被导航上控制器present出来的:
结论同上
第一部分总结:当View controller-based status bar appearance条目value为NO时:
(a)全局设置有效,局部设置几乎(注意措辞!)全无效;
(b)UIApplication单例方式设置始终有效,重写UIViewController两个get方法的方式始终无效。
(二)当Info.plist中没有key:View controller-based status bar appearance条目或其value为YES时(其实就是默认情况);
(1)全局设置:
A:配置项目或Info.plist设置(两者一样)
依次进入【Targets】->【General】->【Deployment Info】,然后可进行进行设置如下:
结论:该方式设置无效(❎)
B:UIApplication单例设置方式
a:方法已弃用,有警告
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent];
[[UIApplication sharedApplication] setStatusBarHidden:YES];
b:新方法,建议使用,无警告
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
结论:该方式设置依旧无效(❎)
(2)局部设置:
A.当前ViewController不在导航上时:
(a)重写UIViewController的两个get方法
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
总结:
statusBarHidden:设置有效(✅)
statusBarStyle:设置有效(✅)
(b)UIApplication单例设置方式
- (void)viewWillAppear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
}
- (void)viewDidDisappear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
[UIApplication sharedApplication].statusBarHidden = NO;
}
结论:设置无效(❎)
B.当前ViewController被导航上控制器present出来时:
(a)重写UIViewController的两个get方法
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
总结:
statusBarHidden:设置有效(✅)
statusBarStyle:设置有效(✅)
(b)UIApplication单例设置方式
- (void)viewWillAppear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
}
- (void)viewDidDisappear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
[UIApplication sharedApplication].statusBarHidden = NO;
}
结论:设置无效(❎)
C.当前ViewController被导航上控制器push出来时:
(a)重写UIViewController的两个get方法
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
总结:
statusBarHidden:设置有效(✅)
statusBarStyle:设置无效(❎)
(b)UIApplication单例设置方式
- (void)viewWillAppear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
}
- (void)viewDidDisappear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
[UIApplication sharedApplication].statusBarHidden = NO;
}
结论:设置无效(❎)
D.当前ViewController作为导航的子视图控制器
(a)重写UIViewController的两个get方法
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
总结:
statusBarHidden:设置有效(✅)
statusBarStyle:设置无效(❎)
原因:ViewController的preferredStatusBarStyle方法并没有更改状态栏风格(字体)的能力,导航栏的preferredStatusBarStyle才具有修改状态栏样式的能力
(b)UIApplication单例设置方式
- (void)viewWillAppear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;
[UIApplication sharedApplication].statusBarHidden = YES;
}
- (void)viewDidDisappear:(BOOL)animated{
// [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;
[UIApplication sharedApplication].statusBarHidden = NO;
}
结论:设置无效(❎)
E.对于导航上的ViewController,更改其statusBarStyle有两种方式:
(a)通过更改navigationBar的BarStyle实现间接更改statusBarStyle:
//UIBarStyleDefault:默认样式,“白纸黑字”、“白底黑字”
self.navigationController.navigationBar.barStyle = UIBarStyleDefault;
//UIBarStyleBlack:“黑纸白字”、“黑底白字”
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
⚠️:iOS 7.0之前,statusBar和navigationBar是分开的;iOS 7.0之后,两者合并为导航栏,所以之后对navigationBar的设置,对statusBar同样有效,如下便是:
//以下设置会让statusBar和navigationBar的背景色都会黑色
self.navigationController.navigationBar.barTintColor = [UIColor blackColor];
(b)自定义导航控制器,并在导航控制器中写入以下代码:
- (UIStatusBarStyle)preferredStatusBarStyle{
UIViewController *top = self.topViewController;
return [top preferredStatusBarStyle];
}
而后再在ViewController中重写两个get方法即可:
- (BOOL)prefersStatusBarHidden{
// return NO;//(默认:不隐藏)
return YES;//隐藏
}
- (UIStatusBarStyle)preferredStatusBarStyle{
// return UIStatusBarStyleDefault;//(默认:字体为黑色)
return UIStatusBarStyleLightContent;//字体为白色
}
第二部分总结:当Info.plist中没有key:View controller-based status bar appearance条目或其value为YES时,
(a)全局设置全无效,局部设置部分(注意措辞!)有效;
(b)UIApplication单例方式设置始终无效,重写UIViewController两个get方法的方式部分有效。
简书首发,整理较乱,请见谅。
参考文章:https://www.jianshu.com/p/1dd3a2aec890