先看例子
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:
与总结二反之