设置status bar字体颜色的优化方案

因为View controller-based status bar appearance 设为YES 后,
如果vc属于Nav,VC状态栏的设置就被nav截获了,不能直接控制。所以这种方式不好用。


优化的解决方案是:
View controller-based status bar appearance 设为NO,
在每个vc中用:
[UIApplication sharedApplication].statusBarStyle
设置状态栏字体的颜色。


如下,在重设状态栏前,先把原来的设置记下来,在vc消失时再设回去。
@property (nonatomic, assign) UIStatusBarStyle previousStatusBarStyle;
-(void)viewDidAppear:(BOOL)animated {
    [super viewDidAppear:animated];
    
    self.previousStatusBarStyle = [UIApplication sharedApplication].statusBarStyle;
    [[UIApplication sharedApplication] setStatusBarStyle:UIStatusBarStyleLightContent animated:YES];
}


- (void)viewDidDisappear:(BOOL)animated {
    [super viewDidDisappear:animated];
    [[UIApplication sharedApplication] setStatusBarStyle:self.previousStatusBarStyle animated:YES];

}


这个作法实际和iOS6是一样的了,此处觉得iOS7中Stautus设置style的方式,设计的并不好。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值