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:
与总结二反之