Navigation bar的注意事項詳解
Bar button item 使用 button 作為 custom view,初始化 isEnabled 為 false,注意順序
需要設置 bar button item 的 custom view 為 button,但一開始 isEnabled 要為 false。
生成一個 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)
如果先設置 isEnabled,后設置 bar button item
leftButton.isEnabled = false navigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton)
結果 isEnabled 還是 true

正確的順序
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton) leftButton.isEnabled = false // or navigationItem.leftBarButtonItem?.isEnabled = false
結果 isEnabled 是 false

改變 navigation bar isTranslucent 屬性會改變 view 的坐標
放置兩個 label。其中, frameLabel 沒有添加約束(NSLayoutConstraint),constraintLabel 左、右、下都有約束,與 view 相接。

設置右上角按鈕動作
navigationItem.rightBarButtonItem = UIBarButtonItem(title: "Change", style: .plain, target: self, action: #selector(rightButtonClicked(_:)))
改變 navigation bar isTranslucent 屬性,顯示 label 的坐標
@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)
}
通過點擊右上角按鈕,來查看變化。
透明時

不透明時

View controller 的 view 坐標改變,Status bar 和 navigation bar 的坐標不變

Navigation bar 從不透明變透明,status bar 和 navigation bar 的坐標都不變。整個 view 下移64,高度減小64,不會超出 window。沒加約束的 frameLabel 坐標不變,但相對 window 的位置隨著 view 一起下移。添加約束的 constraintLabel 的坐標改變,但是相對 window 的位置不變。
如果需要改變 navigation bar isTranslucent 屬性,就要考慮對其他 view 會不會有影響,是否使用約束來定位。
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
相關文章
iOS中containsString和rangeOfString的區(qū)別小結
這篇文章主要給大家總結介紹了關于iOS中containsString和rangeOfString的一些區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-01-01
全面解析iOS應用中自定義UITableViewCell的方法
這篇文章主要介紹了iOS應用開發(fā)中自定義UITableViewCell的方法,示例為傳統(tǒng)的Obejective-C語言,需要的朋友可以參考下2016-04-04

