有时候我们需要根据不同的背景修改状态栏字体的颜色,下面这篇文章主要给大家介绍了关于iOS开发技巧之状态栏字体颜色的设置方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧
正文
iOS开发技巧之状态栏字体颜色的设置方法
状态栏的字体为黑色:UIStatusBarStyleDefault
状态栏的字体为白色:UIStatusBarStyleLightContent
一、在info.plist中,将View controller-based status bar appearance设为NO
状态栏字体的颜色只由下面的属性设定,默认为白色:
|
1
2
|
// default is UIStatusBarStyleDefault[UIApplication sharedApplication].statusBarStyle |
解决个别vc中状态栏字体颜色不同的办法
1、在info.plist中,将View controller-based status bar appearance设为NO.
2、在app delegate中:
|
1
|
[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent; |
3、在个别状态栏字体颜色不一样的vc中
|
1
2
3
4
5
6
7
8
9
|
-(void)viewWillAppear:(BOOL)animated{[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleDefault;}-(void)viewWillDisappear:(BOOL)animated{[super viewWillDisappear:animated];[UIApplication sharedApplication].statusBarStyle = UIStatusBarStyleLightContent;} |
二、在info.plist中,将View controller-based status bar appearance设为YES,或者没有设置。
View controller-based status bar appearance的默认值就是YES。
如果View controller-based status bar appearance为YES。
则[UIApplication sharedApplication].statusBarStyle 无效。
用下面的方法:
1、在vc中重写vc的preferredStatusBarStyle方法。
|
1
2
3
4
5
|
-(UIStatusBarStyle)preferredStatusBarStyle{return UIStatusBarStyleDefault;} |
2、在viewDidload中调用: [self setNeedsStatusBarAppearanceUpdate];
但是,当vc在nav中时,上面方法没用,vc中的preferredStatusBarStyle方法根本不用被调用。
原因是, [self setNeedsStatusBarAppearanceUpdate]发出后,
只会调用navigation controller中的preferredStatusBarStyle方法,
vc中的preferredStatusBarStyley方法跟本不会被调用。
解决办法有两个:
方法一:
设置navbar的barStyle 属性会影响status bar 的字体和背景色。如下。
|
1
2
3
4
5
6
7
8
9
10
11
|
//status bar的字体为白色//导航栏的背景色是黑色。self.navigationController.navigationBar.barStyle = UIBarStyleBlack;//status bar的字体为黑色//导航栏的背景色是白色,状态栏的背景色也是白色。//self.navigationController.navigationBar.barStyle = UIBarStyleDefault; |
方法二:
自定义一个nav bar的子类,在这个子类中重写preferredStatusBarStyle方法:
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
MyNav* nav = [[MyNav alloc] initWithRootViewController:vc];self.window.rootViewController = nav;@implementation MyNav- (UIStatusBarStyle)preferredStatusBarStyle{UIViewController* topVC = self.topViewController;return [topVC preferredStatusBarStyle];} |
附:修改状态栏的背景颜色 (牵扯到UIWindow的层级关系)
|
1
2
3
4
|
/*改变状态栏的背景颜色,因为状态栏的层级比较高,所以按照如下添加就可以出来效果*/UIView* stateView = [[UIView alloc] initWithFrame:CGRectMake(0, -20, SCREEN_WIDTH, 20)];[self.navigationController.navigationBar addSubview:stateView];stateView.backgroundColor = [UIColor purpleColor]; |
备注: 因为在OC中,都应该知道UIWindow有三个层级,如下:
UIKIT_EXTERN const UIWindowLevel UIWindowLevelNormal;
UIKIT_EXTERN const UIWindowLevel UIWindowLevelAlert;
UIKIT_EXTERN const UIWindowLevel UIWindowLevelStatusBar
它们层级的优先级的值分别对应的是:
UIWindowLevelNormal: 0
UIWindowLevelAlert: 1000
UIWindowLevelStatusBar:2000
(而且UIAlertView的层级优先级为1996,UIActionSheet的层级优先级为2001)
优先级
总结:
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对米米素材网的支持。
原文链接:https://blog.csdn.net/iosbird/article/details/52768344

发表评论