真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

Navigationbar的注意事項

    

創(chuàng)新互聯(lián)專業(yè)為企業(yè)提供中方網(wǎng)站建設、中方做網(wǎng)站、中方網(wǎng)站設計、中方網(wǎng)站制作等企業(yè)網(wǎng)站建設、網(wǎng)頁設計與制作、中方企業(yè)網(wǎng)站模板建站服務,十載中方做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡服務。

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 = falsenavigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton)

結(jié)果 isEnabled 還是 true

Navigation bar 的注意事項

正確的順序

navigationItem.leftBarButtonItem = UIBarButtonItem(customView: leftButton)
leftButton.isEnabled = false // or navigationItem.leftBarButtonItem?.isEnabled = false

結(jié)果 isEnabled 是 false

Navigation bar 的注意事項

改變 navigation bar isTranslucent 屬性會改變 view 的坐標

放置兩個 label。其中, frameLabel 沒有添加約束(NSLayoutConstraint),constraintLabel 左、右、下都有約束,與 view 相接。

Navigation bar 的注意事項

設置右上角按鈕動作

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)}

通過點擊右上角按鈕,來查看變化。

透明時

Navigation bar 的注意事項

不透明時

Navigation bar 的注意事項

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

Navigation bar 的注意事項

Navigation bar 從不透明變透明,status bar 和 navigation bar 的坐標都不變。整個 view 下移64,高度減小64,不會超出 window。沒加約束的 frameLabel 坐標不變,但相對 window 的位置隨著 view 一起下移。添加約束的 constraintLabel 的坐標改變,但是相對 window 的位置不變。

如果需要改變 navigation bar isTranslucent 屬性,就要考慮對其他 view 會不會有影響,是否使用約束來定位。


網(wǎng)頁題目:Navigationbar的注意事項
鏈接URL:http://weahome.cn/article/pdehdh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部