設(shè)置按鈕圖片高度
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
let btHeight: CGFloat = 100
let demoButton = UIButton(type: .custom)
demoButton.frame.size = CGSize(width: 50, height: btHeight)
demoButton.setImage(UIImage(named: "img"), for: .normal)
demoButton.setImageHeight(20, buttonHeight: btHeight)
view.addSubview(demoButton)
}
}
extension UIButton {
func setImageHeight(_ height: CGFloat, buttonHeight: CGFloat) {
// 如果不滿足 buttonHeight >= height逃默, 則報錯
assert(buttonHeight >= height, "圖片高度大于按鈕高度!請重新設(shè)置")
assert(height > 0 && buttonHeight > 0, "高度必須大于0")
let gap = (buttonHeight-height)/2
imageView?.contentMode = .scaleAspectFit
imageEdgeInsets = UIEdgeInsets(top: gap, left: 0, bottom: gap, right: 0)
}
}
UINavigationController 自定義了 navigationItem.leftBarButtonItem 的滑動返回
在 UINavigationController 中簇搅,如果 A push B完域, B 中自定義了 navigationItem.leftBarButtonItem
// In B viewcontrcolleer
override func viewDidLoad() {
super.viewDidLoad()
navigationItem.leftBarButtonItem = UIBarButtonItem(title: "XXOO", style: .plain, target: self, action: #selector(backTest))
}
那么此時在該頁面的UINavigationController滑動返回是不起作用的,設(shè)置self.navigationController?.interactivePopGestureRecognizer?.delegate = self 即可正炒窠滑動返回了
// In B viewcontrcolleer
override func viewDidLoad() {
super.viewDidLoad()
navigationItem.leftBarButtonItem = UIBarButtonItem(title: "XXOO", style: .plain, target: self, action: #selector(backTest))
self.navigationController?.interactivePopGestureRecognizer?.delegate = self
}
UINavigationBar 去除默認(rèn)分割線
extension UINavigationBar {
// 去除 UINavigationBar 默認(rèn)分割線
func setWithNoSeperateLine() {
self.setBackgroundImage(UIImage.from(color: UIColor.clear), for: .any, barMetrics: .default)
self.shadowImage = UIImage()
}
// 使用 UINavigationBar 默認(rèn)分割線
func setWithDefaultBar() {
self.setBackgroundImage(nil, for: .any, barMetrics: .default)
self.shadowImage = nil
}
}