iOS 8 Swift Xcode 6 - Set top nav bar bg color and height

前端 未结 3 1790
借酒劲吻你
借酒劲吻你 2021-02-02 03:20

I have looked everywhere and tested all the code snippets posted on Stack, but nothing works for me as I need it to work.

I simply want to set:

  • Nav bar hei
3条回答
  •  旧时难觅i
    2021-02-02 04:20

    After applying the code in the accepted answer, the height doesn't seem to change at all..

    It's not an easy job...and I've surveyed several articles online (most of them in Objective-C).

    The most useful one is this: http://www.emdentec.com/blog/2014/2/25/hacking-uinavigationbar

    But its final solution does not put items in the middle, and it's not in Swift.

    So I come up with a workable version in Swift. Hope it helps some people as I was saved so many precious time on SO.

    Solution in Swift:

    The following code will solve some issues you may have encountered:

    • The title & items are not placed in the middle of the navigation bar
    • The title & items would flick when the user navigates between view controllers

    You need to subclass the UINavigationBar first, and in your storyboard, select the navigation bar element, and in the "Identity Inspector" tab, set the new class as the Custom Class

    import UIKit
    
    class UINavigationBarTaller: UINavigationBar {
        ///The height you want your navigation bar to be of
        static let navigationBarHeight: CGFloat = 64
    
        ///The difference between new height and default height
        static let heightIncrease:CGFloat = navigationBarHeight - 44
    
        override init(frame: CGRect) {
            super.init(frame: frame)
            initialize()
        }
    
        required init?(coder aDecoder: NSCoder) {
            super.init(coder: aDecoder)
            initialize()
        }
    
        private func initialize() {
            let shift = UINavigationBarTaller.heightIncrease/2
    
            ///Transform all view to shift upward for [shift] point
            self.transform =
                CGAffineTransformMakeTranslation(0, -shift)
        }
    
        override func layoutSubviews() {
            super.layoutSubviews()
    
            let shift = UINavigationBarTaller.heightIncrease/2
    
            ///Move the background down for [shift] point
            let classNamesToReposition: [String] = ["_UINavigationBarBackground"]
            for view: UIView in self.subviews {
                if classNamesToReposition.contains(NSStringFromClass(view.dynamicType)) {
                    let bounds: CGRect = self.bounds
                    var frame: CGRect = view.frame
                    frame.origin.y = bounds.origin.y + shift - 20.0
                    frame.size.height = bounds.size.height + 20.0
                    view.frame = frame
                }
            }
        }
    
        override func sizeThatFits(size: CGSize) -> CGSize {
            let amendedSize:CGSize = super.sizeThatFits(size)
            let newSize:CGSize = CGSizeMake(amendedSize.width, UINavigationBarTaller.navigationBarHeight);
            return newSize;
        }
    } 
    

    Also on my gist: https://gist.github.com/pai911/8fa123d4068b61ad0ff7

    iOS 10 Update:

    Unfortunately, this code breaks in iOS 10, there is someone who helps fix it, here you go:

    iOS 10 custom navigation bar height

    And to be clear, this code is kind of hacky since it depends on the navigation bar's internal structure...so if you decide to use it anyway, be prepared for any upcoming changes that may break this code...

提交回复
热议问题