国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

Navigation bar的注意事項詳解

2020-07-26 02:59:10
字體:
來源:轉載
供稿:網友

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 = falsenavigationItem.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 會不會有影響,是否使用約束來定位。

以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 罗源县| 旬阳县| 南平市| 东至县| 松溪县| 佳木斯市| 阳新县| 视频| 镇赉县| 格尔木市| 九寨沟县| 含山县| 顺平县| 常熟市| 阳新县| 湛江市| 治多县| 墨竹工卡县| 城口县| 嘉义县| 抚顺县| 宁德市| 克什克腾旗| 泉州市| 拉萨市| 嵊州市| 宜兰市| 从江县| 秭归县| 平陆县| 双峰县| 保亭| 南溪县| 西吉县| 石狮市| 武城县| 磐安县| 方城县| 板桥市| 东港市| 土默特右旗|