VFL布局問題的解決方法(包括垂直居中和水平居中)

VFL是什么就不多說,在這里主要記錄下在項目使用VFL時遇到的一些問題!

1、多控件的水平布局問題

這里設(shè)置了水平約束,以及控件的寬高約束,且三個控件的centerY是相等的

// 這里有三個控件,需要讓它們處于水平布局狀態(tài)
addSubview(previousBtn)
addSubview(textLabel)
addSubview(nextBtn)

var cons = NSLayoutConstraint
      .constraints(withVisualFormat: "H:|-[previousBtn(30)]-20-[textLabel]-20-[nextBtn(30)]-|",
                   options: .alignAllCenterY,
                   metrics: nil,
                   views: views)
        
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[previousBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)
   
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[nextBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)

2、控件居中問題

上面的三個控件需要設(shè)置垂直居中,(由于水平方向上已經(jīng)有相關(guān)的約束,所以可以不設(shè)置),我這里只設(shè)置textLabel的垂直約束(那個都可以,因?yàn)樗麄兊腸enterY已經(jīng)有相等約束)
這里的實(shí)現(xiàn)有兩套方案

A、VFL約束與Apple封裝的約束混合使用
let views: [String: Any] = ["previousBtn": previousBtn,
                          "textLabel": textLabel,
                          "nextBtn": nextBtn]

添加垂直居中約束

var cons = NSLayoutConstraint
      .constraints(withVisualFormat: "H:|-[previousBtn(30)]-20-[textLabel]-20-[nextBtn(30)]-|",
                   options: .alignAllCenterY,
                   metrics: nil,
                   views: views)
        
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[previousBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)
   
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[nextBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)

// 混合約束                   
cons += [NSLayoutConstraint.init(item: textLabel,
                                  attribute: .centerY,
                                  relatedBy: .equal,
                                  toItem: self,
                                  attribute: .centerY,
                                  multiplier: 1,
                                  constant: 0)]
addConstraints(cons)
B、純VFL約束。

最后必須同時添加水平居中約束和垂直居中約束,否則會報錯

let views: [String: Any] = ["previousBtn": previousBtn,
                          "textLabel": textLabel,
                          "nextBtn": nextBtn,
                          "superview": self]
var cons = NSLayoutConstraint
      .constraints(withVisualFormat: "H:|-[previousBtn(30)]-20-[textLabel]-20-[nextBtn(30)]-|",
                   options: .alignAllCenterY,
                   metrics: nil,
                   views: views)
   
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[previousBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)
   
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[nextBtn(30)]",
                   options: [],
                   metrics: nil,
                   views: views)
   
// VFL設(shè)置居中 必須設(shè)置水平居中和垂直居中
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "H:[textLabel]-(<=0)-[superview]",
                   options: .alignAllCenterY,
                   metrics: nil,
                   views: views)
   
cons += NSLayoutConstraint
      .constraints(withVisualFormat: "V:[textLabel]-(<=0)-[superview]",
                   options: .alignAllCenterX,
                   metrics: nil,
                   views: views)
addConstraints(cons)

Enjoy :)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容