Navigation bar 的注意事项
需要设置 bar button item 的 custom view 为 button,但一开始 isEnabled 要为 false。
生成一个 button
letleftButton=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//ornavigationItem.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 的坐标
@objcprivatefuncrightButtonClicked(_sender:AnyObject){navigationController?.navigationBar.isTranslucent=!navigationController!.navigationBar.isTranslucentupdateLabelContent()}privatefuncupdateLabelContent(){title=navigationController!.navigationBar.isTranslucent?"Translecent":"Opaque"letframeLabelOrigin=frameLabel.frame.originframeLabel.text="Framelabel.x=\(frameLabelOrigin.x),y=\(frameLabelOrigin.y)"letconstraintLabelOrigin=constraintLabel.frame.originconstraintLabel.text="Constraintlabel.x=\(constraintLabelOrigin.x),y=\(constraintLabelOrigin.y)"print("\(title)")print("Statusbarframe:",UIApplication.shared.statusBarFrame)//(0.0,0.0,375.0,20.0)print("Navigationbarframe:",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 会不会有影响,是否使用约束来定位。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。