swift UINavigationController 使用總結(jié)

一. 導(dǎo)航欄 統(tǒng)一返回按鈕樣式

1.創(chuàng)建一個(gè)基類BaseViewController 繼承自UIViewController, 其余所有的ChildViewController都繼承自BaseViewController 在BaseViewController設(shè)置返回按鈕的樣式,代碼如下:

swift 版本:5.0

    //去掉按鈕右邊的文字
    navigationItem.backBarButtonItem = UIBarButtonItem.init(title: "", image:nil, primaryAction: nil, menu: nil)
    //設(shè)置按鈕的顏色
    navigationItem.backBarButtonItem?.tintColor = UIColor(red: 35 / 255, green: 35 / 255, blue: 35 / 255, alpha: 1.0)

以上代碼將就可以實(shí)現(xiàn)返回按鈕樣式統(tǒng)一

二. 自定義導(dǎo)航欄

1.設(shè)置導(dǎo)航欄透明
工作中經(jīng)常會遇到首頁無導(dǎo)航欄第二頁有導(dǎo)航欄這樣的情況,解決方法一般有兩種: 1.隱藏導(dǎo)航欄 2.設(shè)置導(dǎo)航欄透明 由于隱藏導(dǎo)航欄會導(dǎo)致一些特殊的效果,所以接下來介紹一下如何設(shè)置導(dǎo)航欄透明 同上在BaseViewController中添加代碼如下:

    //設(shè)置導(dǎo)航欄按鈕為透明色圖片
    navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default)
    //設(shè)置導(dǎo)航欄陰影為透明色圖片
    navigationController?.navigationBar.shadowImage = UIImage()

這樣導(dǎo)航欄就透明了,效果如下:


Simulator Screen Shot - iPhone 11 - 2021-06-12 at 16.52.21.png

但是這樣有個(gè)問題,所有的導(dǎo)航欄都會變透明,解決方案代碼如下:

   func addNavBar(_ color:UIColor){
        
        //設(shè)置導(dǎo)航欄高度(此處可根據(jù)導(dǎo)航欄高度的不同來獲取導(dǎo)航欄高度)
        let size = CGSize(width: view.bounds.width, height: 91)
        //純色創(chuàng)建UIImage
        UIGraphicsBeginImageContextWithOptions(size, false, 0.0)
        color.setFill()
        UIRectFill(CGRect(origin: .zero, size: size))
        let image = UIGraphicsGetImageFromCurrentImageContext()
        UIGraphicsEndImageContext()
        //將UIImage添加到UIImageView
        let navImageView = UIImageView(image: image)
        view .addSubview(navImageView)
    }

在需要導(dǎo)航欄的頁面,調(diào)用方法如下:

    override func viewDidLoad() {
        super.viewDidLoad()
        
        self.title = "第二頁"
        //添加導(dǎo)航欄
        addNavBar(.red)
    }

效果如下圖:


Simulator Screen Shot - iPhone 11 - 2021-06-12 at 17.02.31.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容