前言
iPhone X在主界面是UITabBarController的情况下,如果控制器的hidesBottomBarWhenPushed属性设为true,进行push操作之后会出现tabBar高度错乱的现象,先变矮一截,然后返回的时候又弹回到正常高度,非常影响使用感受,这应该属于iOS 11在iPhone X设备下自身的bug。(iOS 11为了适配全面屏真的搞出很多UI上的bug,恶心)
问题复现
首先,UITabBarController上是一个UINavigationController
然后在UINavigationController上present一个UIViewController,dismiss掉
然后创建一个UIViewController,设置hidesBottomBarWhenPushed为true,pushViewController
这个时候你会发现tabBar瞬间变矮了,里面的图标都漏出来了,非常不美观
然后返回,你会发现tabBar又弹回正常高度了,这不膈应人吗
解决思路
既然我们知道了是tabBar的高度变化引起的,那么我们就对tabBar的高度下手,网上看到一些自定义UITabBar的方法,很不错,但是稍微麻烦了点,我的方法是用KVO监听tabBar的frame,当frame改变时,我们取一个高度最大的值重新布局tabBar就行了,没有特殊定制情况下这种方式完全可以解决问题了
代码
class MyTabBarController: UITabBarController {
override func viewDidLoad() {
super.viewDidLoad()
tabBar.addObserver(self, forKeyPath: "frame", options: [.old, .new], context: nil)
}
override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {
if let tabBar = object as? UITabBar, keyPath == "frame" {
if let oldFrame = change?[.oldKey] as? CGRect, let newFrame = change?[.newKey] as? CGRect {
if oldFrame.size != newFrame.size {
if oldFrame.height > newFrame.height {
tabBar.frame = oldFrame
} else {
tabBar.frame = newFrame
}
}
}
}
}
deinit {
tabBar.removeObserver(self, forKeyPath: "frame")
}
}
用OC的小伙伴自己改成OC代码就行了,iPhone X的tabBar的高度为什么会在49和83之间来回跳,懵逼脸