更改状态栏,导航栏颜色的方法

本文介绍如何在iOS应用中定制状态栏的颜色及外观,包括前景部分(如电池、时间图标)和背景部分的颜色调整方法,提供了通过plist配置和代码实现的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

前景部分:就是指的显示电池、时间等部分;
背景部分:就是显示黑色或者图片的背景部分;

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

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

默认的黑色(UIStatusBarStyleDefault)
白色(UIStatusBarStyleLightContent)
可以设置的地方有两个:plist设置里面 和 程序代码里
初始化设置:导航栏设置为不透明并给了"标题"与状态栏文字作对比

                  self.edgesForExtendedLayout = 0;
                   self.navigationItem.title = @"标题";

https://i-blog.csdnimg.cn/blog_migrate/2ec2949d2ac7be4d34144db53e254f34.webp?x-image-process=image/format,png

改变状态栏的方法
方法一:
1、plist
View controller-based status bar appearance 设置为 NO


https://i-blog.csdnimg.cn/blog_migrate/583e49b84ec56f5639e33d2494bca02e.webp?x-image-process=image/format,png

2、代码设置

[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;

效果如下:




https://i-blog.csdnimg.cn/blog_migrate/f6eb8913d86881e784021041742ce35e.webp?x-image-process=image/format,png

方法二:
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;

https://i-blog.csdnimg.cn/blog_migrate/5948f0399a7e33db251594688614c2bf.webp?x-image-process=image/format,png
或者在控制器中重写 preferredStatusBarStyle方法,修改状态栏颜色
- (UIStatusBarStyle)preferredStatusBarStyle {
//    return UIStatusBarStyleLightContent;
    return UIStatusBarStyleDefault;
}
(二)设置statusBar的【背景部分】
背景部分,简单来说,就是背景色;改变方法有两种:

1、系统提供的方法

navigationBar的setBarTintColor接口,用此接口可改变statusBar的背景色
self.navigationController.navigationBar.barTintColor = [UIColor greenColor];

https://i-blog.csdnimg.cn/blog_migrate/3d7c821d1bd7d1a0ec4aff13b13efcec.webp?x-image-process=image/format,png
如果想将状态栏和导航栏字体全变为白色,这样就行
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;

https://i-blog.csdnimg.cn/blog_migrate/c9fb9138f10fb88612baf61b1f877d73.webp?x-image-process=image/format,png
如果只想改变导航栏的字体颜色,可以这样
[self.navigationController.navigationBar setTitleTextAttributes:@{NSForegroundColorAttributeName:[UIColor redColor]}];

https://i-blog.csdnimg.cn/blog_migrate/3bf5c5431a02350790a50bef4aa66b2e.webp?x-image-process=image/format,png
或者可以设置背景图片
[self.navigationController.navigationBar setBackgroundImage:[UIImage imageNamed:@"image01"] forBarMetrics:UIBarMetricsDefault];

https://i-blog.csdnimg.cn/blog_migrate/cee068fe7e1247ad826c62603b1049d9.webp?x-image-process=image/format,png

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];


https://i-blog.csdnimg.cn/blog_migrate/9c5b62146acc09747448f89942b4c025.webp?x-image-process=image/format,png

另外图片透明处理
navigationBar为透明,注释掉self.edgesForExtendedLayout = 0;

// self.edgesForExtendedLayout = 0;
 [self.navigationController.navigationBar setBackgroundImage:[UIImage new] forBarMetrics:UIBarMetricsDefault]
 self.navigationController.navigationBar.shadowImage = [UIImage new];

https://i-blog.csdnimg.cn/blog_migrate/7be39384da364def215b154a71c290fb.webp?x-image-process=image/format,png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值