我有一个我创建的自定义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个标签,如何在UIButtons
的textLabel
上设置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
设置。