简单修复iPhone X设备tabBar高度错乱的问题

前言

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之间来回跳,懵逼脸

你可能感兴趣的:(简单修复iPhone X设备tabBar高度错乱的问题)