美文网首页
iOS 更改状态栏、导航栏颜色的几种方法

iOS 更改状态栏、导航栏颜色的几种方法

作者: SimpleBK | 来源:发表于2017-03-08 10:04 被阅读0次

    ios上状态栏 就是指的最上面的20像素高的部分

    状态栏分前后两部分,要分清这两个概念,后面会用到:

    前景部分:就是指的显示电池、时间等部分;

    背景部分:就是显示黑色或者图片的背景部分;

    (一)设置statusBar的【前景部分】

    简单来说,就是设置显示电池电量、时间、网络部分标示的颜色, 这里只能设置两种颜色:

    默认的黑色(UIStatusBarStyleDefault)

    白色(UIStatusBarStyleLightContent)

    可以设置的地方有两个:plist设置里面 和 程序代码里

    初始化设置:导航栏设置为不透明并给了"标题"与状态栏文字作对比

    改变状态栏的方法

    方法一:

    1、plist

    View controller-based status bar appearance 设置为 NO

    2、代码设置

    [UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

    //相对于上面的接口,这个接口可以动画的改变statusBar的前景色

    [[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];

    方法二:

    1、plist

    View controller-based status bar appearance 设置为 YES 或者默认(不设置)

    注意:

    如果View controller-based status bar appearance为YES。

    则[UIApplication sharedApplication].statusBarStyle 无效。

    2、代码设置

    self.navigationController.navigationBar.barStyle = UIBarStyleBlack;

    或者在控制器中重写 preferredStatusBarStyle方法,修改状态栏颜色

     其他方法

    不仅如此,ios还很贴心的在UIViewController也增加了几个接口,

    目的是让状态栏根据当前显示的UIViewController来定制statusBar的前景部分。

    - (UIStatusBarStyle)preferredStatusBarStyle;

    - (UIViewController *)childViewControllerForStatusBarStyle;

    - (void)setNeedsStatusBarAppearanceUpdate

    - (UIStatusBarStyle)preferredStatusBarStyle:

    在你自己的UIViewController里重写此方法,返回你需要的值(UIStatusBarStyleDefault 或者 UIStatusBarStyleLightContent);

    注意:

    这里如果你只是简单的return一个固定的值,那么该UIViewController显示的时候,程序就会马上调用该方法,来改变statusBar的前景部分;

    如果在该UIViewController已经在显示在当前,你可能还要在当前页面不时的更改statusBar的前景色,那么,你首先需要调用下面的setNeedsStatusBarAppearanceUpdate方法(这个方法会通知系统去调用当前UIViewController的preferredStatusBarStyle方法), 这个和UIView的setNeedsDisplay原理差不多(调用UIView对象的setNeedsDisplay方法后,系统会在下次页面刷新时,调用重绘该view,系统最快能1秒刷新60次页面,具体要看程序设置)。

    - (UIViewController *)childViewControllerForStatusBarStyle:

    这个接口也很重要,默认返回值为nil。当我们调用setNeedsStatusBarAppearanceUpdate时,系统会调用application.window的rootViewController的preferredStatusBarStyle方法,我们的程序里一般都是用UINavigationController做root,如果是这种情况,那我们自己的UIViewController里的preferredStatusBarStyle根本不会被调用;

    这种情况下childViewControllerForStatusBarStyle就派上用场了,

    我们要子类化一个UINavigationController,在这个子类里面重写childViewControllerForStatusBarStyle方法,如下:

    - (UIViewController *)childViewControllerForStatusBarStyle{

    return self.topViewController;

    }

    上面代码的意思就是说,不要调用我自己(就是UINavigationController)的preferredStatusBarStyle方法,而是去调用navigationController.topViewController的preferredStatusBarStyle方法,这样写的话,就能保证当前显示的UIViewController的preferredStatusBarStyle方法能影响statusBar的前景部分。

    另外,有时我们的当前显示的UIViewController可能有多个childViewController,重写当前UIViewController的childViewControllerForStatusBarStyle方法,让childViewController的preferredStatusBarStyle生效(当前UIViewController的preferredStatusBarStyle就不会被调用了)。

    简单来说,只要UIViewController重写的的childViewControllerForStatusBarStyle方法返回值不是nil,那么,UIViewController的preferredStatusBarStyle方法就不会被系统调用,系统会调用childViewControllerForStatusBarStyle方法返回的UIViewController的preferredStatusBarStyle方法。

    - (void)setNeedsStatusBarAppearanceUpdate:

    让系统去调用application.window的rootViewController的preferredStatusBarStyle方法,如果rootViewController的childViewControllerForStatusBarStyle返回值不为nil,则参考上面的讲解。

    (二)设置statusBar的【背景部分】

    背景部分,简单来说,就是背景色;改变方法有两种:

    1、系统提供的方法

    navigationBar的setBarTintColor接口,用此接口可改变statusBar的背景色

    self.navigationController.navigationBar.barTintColor = [UIColor greenColor];

    如果想将状态栏和导航栏字体全变为白色,这样就行

    self.navigationController.navigationBar.barStyle = UIBarStyleBlack;

    如果只想改变导航栏的字体颜色,可以这样

    [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor]}];

    还可以改变字体大小

    [self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor],NSFontAttributeName:[UIFont systemFontOfSize:25]}];

    或者可以设置背景图片

    [self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"image01"] forBarMetrics:UIBarMetricsDefault];

    2、另辟蹊径

    创建一个UIView,

    设置该UIView的frame.size 和statusBar大小一样,

    设置该UIView的frame.origin 为{0,-20},

    设置该UIView的背景色为你希望的statusBar的颜色,

    在navigationBar上addSubView该UIView即可。

    原理:

    状态栏区域相对于navigationBar的区域  {0,-20,self.view.bounds.size.width,20}

    除了改变状态栏的前景色(文字颜色,wifi颜色,时间颜色,电池颜色),就是改变背景色.由于状态栏区域上的控件是隐藏的,所以只要在状态栏区域被渲染了颜色,状态栏的背景颜色就跟着一起改变,从而改变了状态栏的背景颜色.

    UIView *statusBarView = [[UIView alloc]  initWithFrame:CGRectMake(0, -20,    self.view.bounds.size.width, 20)];

    statusBarView.backgroundColor = [UIColor greenColor];

    [self.navigationController.navigationBar addSubview:statusBarView];

    另外图片透明处理

    navigationBar为透明,注释掉self.edgesForExtendedLayout = 0;

    // self.edgesForExtendedLayout = 0;

    [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault]

    self.navigationController.navigationBar.shadowImage = [UIImage new];

    相关文章

      网友评论

          本文标题:iOS 更改状态栏、导航栏颜色的几种方法

          本文链接:https://www.haomeiwen.com/subject/odfbgttx.html