编程设置Uibutton内部标签的框架大小



我有一个我创建的自定义uibutton。在按钮内,我有2个标签,一个标签在另一个标签上方。顶部是标题,所以它更大一些,底部有点小。我的目标是让两个标签完全涵盖整个按钮,因此:顶部标签将覆盖按钮的顶部2/3部分,底部将覆盖按钮的其余1/3。我的目标离达到不远,但我得到了怪异的行为 - 标签有点超出按钮,在某些情况下它们消失了(我可以单击按钮,但看不到标签)。这是我的自定义UIBUTTON供参考,我希望该代码无论如何都会帮助人们:

class ButtonWithStats: UIButton {
var num: Int
var name: String
var nameLabel: UILabel?
var numLabel: UILabel?
required init?(coder aDecoder: NSCoder) {
   // fatalError("init(coder:) has not been implemented")
    self.num = 0
    self.name = ""
    self.numLabel = UILabel(frame: CGRect(x: 0, y: 0, width: 0, height: 0)) //just to init the labels.
    self.nameLabel = UILabel(frame: CGRect(x: 0, y: 0, width: 0, height: 0))
    self.numLabel?.textAlignment = .center
    self.nameLabel?.textAlignment = .center
    self.numLabel?.textColor = UIColor.purple
    self.nameLabel?.textColor = UIColor.black
    self.numLabel?.font = UIFont.init(name: "Helvetica", size: 11)
    self.nameLabel?.font = UIFont.init(name: "Helvetica", size: 13)
    super.init(coder: aDecoder)
}
func setButton(numInput: Int, nameInput: String){
    self.num = numInput
    self.name = nameInput
    self.setLabels()
}
private func setLabels(){
    numLabel?.text = String(self.num)
    nameLabel?.text = self.name
    let widthForName = self.frame.width
    let heightForName = self.frame.height * 2 / 3
    nameLabel?.center = self.center
    nameLabel?.frame = CGRect(origin: self.frame.origin, size: CGSize(width: widthForName, height: heightForName))
    let widthForNum = self.frame.width
    let heightForNum = self.frame.height * 1 / 3
    let yForNum = (self.frame.height * 2 / 3) //+ self.frame.origin.y
    numLabel?.frame = CGRect(x: self.frame.origin.x, y: yForNum, width: widthForNum, height: heightForNum)
    self.addSubview(nameLabel!)
    self.addSubview(numLabel!)
    print("@@@@@@@@@@@@@@@@@@@@@@@@@")
    print("Button (self.nameLabel?.text) frame is: (self.frame)")
    print("Label frame is: (self.nameLabel?.frame)")
    print("Num frame is: (self.numLabel?.frame)")
    print("@@@@@@@@@@@@@@@@@@@@@@@@@")
}
}

我的控制台打印此数据:

@@@@@@@@@@@@@@@@@@@@@@@@@
Button Optional("button one") frame is: (257.5, 0.0, 64.5, 33.0)
Label frame is: Optional((257.5, 0.0, 64.5, 22.0))
Num frame is: Optional((257.5, 22.0, 64.5, 11.0))
@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@
Button Optional("Button two") frame is: (129.0, 0.0, 64.0, 33.0)
Label frame is: Optional((129.0, 0.0, 64.0, 22.0))
Num frame is: Optional((129.0, 22.0, 64.0, 11.0))
@@@@@@@@@@@@@@@@@@@@@@@@@
@@@@@@@@@@@@@@@@@@@@@@@@@
Button Optional("Button three") frame is: (0.0, 0.0, 64.5, 33.0)
Label frame is: Optional((0.0, 0.0, 64.5, 22.0))
Num frame is: Optional((0.0, 22.0, 64.5, 11.0))
@@@@@@@@@@@@@@@@@@@@@@@@@

而不是添加2个标签,如何在UIButtonstextLabel上设置numberOfLines

button.titleLabel?.numberOfLines = 2

或或者,将两个标签作为子视图添加垂直UIStackView,并设置stackView.frame = button.bounds

let stackView = UIStackView(arrangedSubviews: [numLabel, nameLabel])
stackView.frame = buttonView.bounds
addSubview(stackView)

您可以调整stackView.spacing/layoutMargins等,以根据需要定位标签

要使numLabel的高度是nameLabel的高度的两倍,您可以使用…

使用集合约束。
numLabel.heightAnchor.constraint(equalTo: nameLabel.heightAnchor, multiplier: 2)

我建议您在故事板/XIB中执行此操作,但是如果您需要以编程方式进行操作,则可能会发现创建一个XIB来实验UIStackView设置。

最新更新