Navigation bar的注意事項(xiàng)詳解
Bar button item 使用 button 作為 custom view,初始化 isEnabled 為 false,注意順序
需要設(shè)置 bar button item 的 custom view 為 button,但一開始 isEnabled 要為 false。
生成一個(gè) button
let leftButton = UIButton(frame: CGRect(x: 0, y: 0, width: 80, height: 44)) leftButton.setTitleColor(UIColor.green, for: .normal) leftButton.setTitleColor(UIColor.red, for: .disabled) leftButton.setTitle("Enabled", for: .normal) leftButton.setTitle("Disabled", for: .disabled) leftButton.addTarget(self, action: #selector(leftButtonClicked(_:)), for: .touchUpInside)
如果先設(shè)置 isEnabled,后設(shè)置 bar button item
leftButton.isEnabled = false navigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton)
結(jié)果 isEnabled 還是 true
正確的順序
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton) leftButton.isEnabled = false // or navigationItem.leftBarButtonItem?.isEnabled = false
結(jié)果 isEnabled 是 false
改變 navigation bar isTranslucent 屬性會(huì)改變 view 的坐標(biāo)
放置兩個(gè) label。其中, frameLabel 沒有添加約束(NSLayoutConstraint),constraintLabel 左、右、下都有約束,與 view 相接。
設(shè)置右上角按鈕動(dòng)作
navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Change", style: .plain, target: self, action: #selector(rightButtonClicked(_:)))
改變 navigation bar isTranslucent 屬性,顯示 label 的坐標(biāo)
@objc private func rightButtonClicked(_ sender: AnyObject) { navigationController?.navigationBar.isTranslucent = !navigationController!.navigationBar.isTranslucent updateLabelContent() } private func updateLabelContent() { title = navigationController!.navigationBar.isTranslucent ? "Translecent" : "Opaque" let frameLabelOrigin = frameLabel.frame.origin frameLabel.text = "Frame label. x = \(frameLabelOrigin.x), y = \(frameLabelOrigin.y)" let constraintLabelOrigin = constraintLabel.frame.origin constraintLabel.text = "Constraint label. x = \(constraintLabelOrigin.x), y = \(constraintLabelOrigin.y)" print("\(title)") print("Status bar frame:", UIApplication.shared.statusBarFrame) // (0.0, 0.0, 375.0, 20.0) print("Navigation bar frame:", navigationController!.navigationBar.frame) // (0.0, 20.0, 375.0, 44.0) }
通過點(diǎn)擊右上角按鈕,來查看變化。
透明時(shí)
不透明時(shí)
View controller 的 view 坐標(biāo)改變,Status bar 和 navigation bar 的坐標(biāo)不變
Navigation bar 從不透明變透明,status bar 和 navigation bar 的坐標(biāo)都不變。整個(gè) view 下移64,高度減小64,不會(huì)超出 window。沒加約束的 frameLabel 坐標(biāo)不變,但相對 window 的位置隨著 view 一起下移。添加約束的 constraintLabel 的坐標(biāo)改變,但是相對 window 的位置不變。
如果需要改變 navigation bar isTranslucent 屬性,就要考慮對其他 view 會(huì)不會(huì)有影響,是否使用約束來定位。
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!
相關(guān)文章
IOS正則表達(dá)式之驗(yàn)證密碼身份證手機(jī)號(hào)
這篇文章主要介紹了IOS正則表達(dá)式之驗(yàn)證密碼身份證手機(jī)號(hào)的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-10-10總結(jié)IOS關(guān)閉鍵盤/退出鍵盤的五種方式
IOS開發(fā)中經(jīng)常要用到輸入框,默認(rèn)情況下點(diǎn)擊輸入框就會(huì)彈出鍵盤,但是必須要實(shí)現(xiàn)輸入框return的委托方法才能取消鍵盤的顯示,對于用戶體驗(yàn)來說很不友好,我們可以實(shí)現(xiàn)例如點(diǎn)擊鍵盤以外的空白區(qū)域來將鍵盤關(guān)閉的功能,以下是我總結(jié)出的幾種關(guān)閉鍵盤的方法。2016-08-08iOS實(shí)現(xiàn)播放遠(yuǎn)程網(wǎng)絡(luò)音樂的核心技術(shù)點(diǎn)總結(jié)
本篇文章主要介紹了iOS播放遠(yuǎn)程網(wǎng)絡(luò)音樂的核心技術(shù),采用ios系統(tǒng)自帶的AVFoundation框架來實(shí)現(xiàn),有需要的朋友可以了解一下。2016-11-11iOS中containsString和rangeOfString的區(qū)別小結(jié)
這篇文章主要給大家總結(jié)介紹了關(guān)于iOS中containsString和rangeOfString的一些區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-01-01全面解析iOS應(yīng)用中自定義UITableViewCell的方法
這篇文章主要介紹了iOS應(yīng)用開發(fā)中自定義UITableViewCell的方法,示例為傳統(tǒng)的Obejective-C語言,需要的朋友可以參考下2016-04-04IOS設(shè)置QQ小紅點(diǎn)消除的方法(一鍵退朝)
這篇文章主要介紹了IOS設(shè)置QQ小紅點(diǎn)消除的方法(一鍵退朝),對ios設(shè)置小紅點(diǎn)消除相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-01-01