为了账号安全,请及时绑定邮箱和手机立即绑定

谈谈StatusBar相关的东西

标签:
iOS 面试

先看例子

1、没有导航栏的情况

  class ViewController: UIViewController {
    var style: UIStatusBarStyle = .default
    override var preferredStatusBarStyle: UIStatusBarStyle
    {
        print("无导航栏就会进来了。")
        return self.style
    }
    
    var changeBtn: UIButton!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = .purple
        let btn = UIButton.init(frame: CGRect(x: 100, y: 100, width: 100, height: 50))
        btn.backgroundColor = .gray
        self.changeBtn = btn
        btn.setTitle("hit me", for: .normal)
        btn.addTarget(self, action: #selector(click), for: .touchUpInside)
        self.view.addSubview(btn)
    }

    @objc func click() {
        // 1、没有导航栏的情况
        if self.style == .lightContent {
            self.style = .default
        }else {
            self.style = .lightContent
        }
        setNeedsStatusBarAppearanceUpdate() // 在需要更新的时候调用 setNeedsStatusBarAppearanceUpdate() 方法来触发它。
    }
}

此时会打印 无导航栏就会进来了。

2、有导航栏的情况
如果我们使用了导航控制器 UINavigationController, 且它的 navigationBar 没有被隐藏,那么会发现即使重写 preferredStatusBarStyle 方法,这个方法也不会被调用。因为此时状态栏的样式是根据导航栏的样式来自动变换的。

@objc func click() {
    // 2、有导航栏的情况
    if let navigationBar = self.navigationController?.navigationBar {
        if navigationBar.barStyle == .default {
            navigationBar.barStyle = .black
        } else {
            navigationBar.barStyle = .default
        }
    }
}

此时不会打印 无导航栏就会进来了。

注意:上面的条件都是在info.pllist 设置
<key>UIViewControllerBasedStatusBarAppearance</key> <true/>或者不设置的情况下(跟true是一样效果)

总结:

一、不会触发的preferredStatusBarStyle情况:
1、<key>UIViewControllerBasedStatusBarAppearance</key>设置为false
2、有导航栏且navigationBar没有被隐藏

二、<key>UIViewControllerBasedStatusBarAppearance</key>设置为false:
1、preferredStatusBarStyle不会被触发
2、navigationBar.barStyle = .black 不起作用
3、application.statusBarStyle = .lightContent会起作用
4、在 General -> Deployment Info 中,将 Status Bar Style 设置成 Light会起作用(3优先4)
三、<key>UIViewControllerBasedStatusBarAppearance</key>设置为true:
与总结二反之

点击查看更多内容
1人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
软件工程师
手记
粉丝
6445
获赞与收藏
781

关注作者,订阅最新文章

阅读免费教程

感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消