zoukankan      html  css  js  c++  java
  • Navigation bar 的注意事项

    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,  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 会不会有影响,是否使用约束来定位。

    转载请注明出处:http://www.cnblogs.com/silence-cnblogs/p/6262471.html

  • 相关阅读:
    CodeBlocks 中fopen函数不支持命令 “r”
    【转载】分享一些Qt学习资源,欢迎下载
    【转载】知乎答案----孙志岗----Google 发布了程序员养成指南,国内互联网巨头是否也有类似的指南和课程推荐
    【转载】谷歌公司推荐的程序员必修课(英文教程)
    【转载】张逸--ThoughtWorks(中国)程序员读书雷达
    在windows环境下,为什么要用Notepad++编辑?
    【转载】池建强--趣谈个人建站
    JAVA入门第二季 第一章 类和对象
    CAP理论总结
    分布式通信方式之消息队列之RocketMQ
  • 原文地址:https://www.cnblogs.com/silence-cnblogs/p/6262471.html
Copyright © 2011-2022 走看看