0
点赞
收藏
分享

微信扫一扫

iOS开发之全面讲解的改变系统顶部状态栏的颜色变化


ios上状态栏 就是指的最上面的20像素高的部分
状态栏分前后两部分,要分清这两个概念,后面会用到:

  • 前景部分:就是指的显示电池、时间等部分;
  • 背景部分:就是显示黑色或者图片的背景部分;
    如下图:前景部分为白色,背景部分为黑色
  • iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏

​注意:这里只涉及到ios7以及更高版本,低版本下面的讲解可能无效。​

1.单个视图View没有导航控制器包装的情况下

  • 默认情况下,启动状态栏和进入程序后的状态栏都是默认的颜色-黑色,如下图:
  • iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏_02


  • 默认情况.gif

1.只设置启动状态栏颜色改变(白色),而视图中状态栏不变化(默认黑色),做如下的设置即可,两种方式不管先设置哪一个,另一个都会相应的变化,如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_ios开发_03

在General里面做的修改


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_导航栏_04

Info.plist文件中生成的相应配置


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏_05

只有启动栏颜色改变.gif

2.设置启动状态栏颜色改变(白色),视图中的状态栏也变成白色(保持上面的设置),有两种设置方式:

a.在Info.plist里面添加一行​​View controller-based status bar appearance = NO​​ 即可,如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏颜色_06

在Info.plist里面设置

b.在视图控制器中添加代码,如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏颜色_07

在.m文件中添加代码

效果如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏颜色_08

启动和视图一起改变.gif

3.设置视图中状态栏的颜色为白色,启动程序时的状态栏为默认颜色(黑色),没有做1.中的任何设置情况下,在控制器.m文件中添加如下代码(即2.->b.图所示):

- (UIStatusBarStyle)preferredStatusBarStyle {
return UIStatusBarStyleLightContent;
}

效果如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏_09

只改变视图状态栏颜色.gif

2.视图作为导航控制器的根控制器的情况下

  • 在这种情况下,启动画面和视图的状态栏都是默认颜色(黑色),即使是在AppDelegate.m文件的didFinishLaunching的方法中添加下面代码:
    ​​​[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;​​并且在视图控制器中添加如1.->2.->b.的图中的代码也是没有效果的。


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_ios开发_10

各种无效果.gif

1.设置启动画面的状态栏为白色,视图中的状态栏为默认(黑色),如1.->1.中的设置即可,效果如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏_11

导航栏包装的情况-1.gif

此时,如果想要视图的状态栏变为白色,不管是在AppDelegate.m文件中添加
​​​[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;​​同时在视图控制器中添加1.->2.->b.的图中的代码,都是然并卵,已测试。

2.设置启动画面和视图中的状态栏颜色都为白色(保持2.->1.中的设置),方式同样有两种:

a.在Info.plist里面添加一行View controller-based status bar appearance = NO 即可,如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏颜色_06

在Info.plist里面设置

b.此时如果单单在视图控制器.m文件中添加如下代码是不够的,

- (UIStatusBarStyle)preferredStatusBarStyle { return UIStatusBarStyleLightContent; }

同时需要在导航控制器.m文件中添加下面的代码才能达到效果(careful)

- (UIViewController *)childViewControllerForStatusBarStyle{ return self.topViewController; }

如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_ios开发_13

导航栏包装的情况-2.gif

2.只设置视图控制器状态栏颜色为白色,启动画面的状态栏为默认(黑色),把Info.plist文件中的 ​​Status bar style = UIStatusBarStyleLightContent​​设置去掉,保持2.->2.->b.中的代码设置即可,效果如下图:


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_导航栏_14

导航栏包装的情况-3.gif

3.小结

1.在AppDelegate.m文件中添加如下代码,没有一点儿毛用,
​​​[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;​​​/​​[[UIApplication sharedApplication]setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];(被弃用)​​2.目前所测试均为系统样式,不包含自定义的情况。
3.以上如有疏漏或错误的地方,忘及时沟通交流,尽快更正,不能传播误导信息。

4.补充

  • 要想在工程中启动和视图中的状态栏都是白色,用下面的方法简单配置下就行。
    1.设置Status Bar Style为Light.
  • iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏_15


  • Info.plist文件中生成的相应配置

2.在plist文件中添加 View controller-based status bar appearance = NO。


iOS开发之全面讲解的改变系统顶部状态栏的颜色变化_状态栏颜色_06

在Info.plist里面设置

举报

相关推荐

0 条评论