美文网首页
简单修复iPhone X设备tabBar高度错乱的问题

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

作者: 明明是个呆子 | 来源:发表于2018-04-25 10:42 被阅读0次

    前言

    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高度错乱的问题

          本文链接:https://www.haomeiwen.com/subject/jiyelftx.html