一、知识普及
ios上状态栏 就是指的最上面的20像素高的部分
状态栏分前后两部分,要分清这两个概念,后面会用到:
- 前景部分:就是指的显示电池、时间等部分;
- 背景部分:就是显示黑色或者图片的背景部分;
如下图:前景部分为白色,背景部分为黑色
注意:这里只涉及到ios7以及更高版本,低版本下面的讲解可能无效。
二、设置statusBar的【前景部分】
简单来说,就是设置显示电池电量、时间、网络部分标示的颜色,
这里只能设置两种颜色:
- 默认的黑色(
UIStatusBarStyleDefault) - 白色(
UIStatusBarStyleLightContent)
可以设置的地方有两个:plist设置里面和程序代码里
1.plist设置statusBar
在plist里增加一行UIStatusBarStyle(或者是Status bar style也可以),这里可以设置两个值,就是上面提到那两个 UIStatusBarStyleDefault和UIStatusBarStyleLightContent
这样在app启动的launch页显示的时候,statusBar的样式就是上面plist设置的风格。
2.程序代码里设置statusBar
全局设置状态栏
首先将info.plist文件的View controller-based status bar appearance设置为NO,即可开启全局设置,也就是说你在VC中对状态栏的控制都将无效。
然后在AppDelegate.m中进行全局设置
[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent]; 或者
//相对于上面的接口,这个接口可以动画的改变
statusBar的前景色[[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];
补充:可以通过viewWillAppearance、viewWillDisappear方法重新设置部分页面的状态栏
分页面设置状态栏
首先将info.plist文件的View controller-based status bar appearance设置为YES,即可开启由VC来控制状态栏的功能,在这种模式下,全局的设置将无效!!所以我们必须逐个页面对状态栏进行设置,否则状态栏将维持默认的黑色字体和默认为显示状态。
- 当VC不在
UINavigationController中时,在VC中添加一个方法
- (UIStatusBarStyle)preferredStatusBarStyle
{
//返回白色
return UIStatusBarStyleLightContent;
//返回黑色
//return UIStatusBarStyleDefault;
}
保险起见,在view的某个加载阶段比如viewWillAppear中,执行:
[self setNeedsStatusBarAppearanceUpdate];
- 当VC在
UINavigationController中时,VC并不能通过1)的方式控制状态栏的颜色,详见本文后面的参考资料,那么这个时候,有一个trick的方法可以在VC中间接的控制:
self.navigationController.navigationBar.barStyle = UIBarStyleBlack;
三、设置statusBar的【背景部分】
背景部分,简单来说,就是背景色;改变方法有两种:
1.系统提供的方法:
navigationBar的setBarTintColor接口,用此接口可改变statusBar的背景色
注意:一旦你设置了navigationBar的- (void)setBackgroundImage:(UIImage *)backgroundImage forBarMetrics:(UIBarMetrics)barMetrics接口,那么上面的setBarTintColor接口就不能改变statusBar的背景色,statusBar的背景色就会变成纯黑色。
(注意:如果当前window的背景颜色没有设置,statusBar的背景色也是纯黑色)
2.另辟蹊径:
创建一个UIView,
设置该UIView的frame.size和statusBar大小一样,
设置该UIView的frame.origin为{0,-20},
设置该UIView的背景色为你希望的statusBar的颜色,
在navigationBar上addSubView该UIView即可。
参考:
https://segmentfault.com/a/1190000003482218
http://www.jianshu.com/p/e28e32d896d8
http://www.cnblogs.com/zxykit/p/5197893.html
http://blog.csdn.net/r614288863/article/details/46830403










网友评论