导航栏与状态栏设置

导航栏与状态栏设置_第1张图片
冰与火之歌

前言

//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】,然后可进行进行设置如下:


导航栏与状态栏设置_第2张图片
image.png

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】,然后可进行进行设置如下:


导航栏与状态栏设置_第3张图片
image.png

结论:该方式设置无效(❎)

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

你可能感兴趣的:(导航栏与状态栏设置)