Как нарисовать границу вокруг UILabel?
Есть ли способ для UILabel нарисовать границу вокруг себя? Это полезно для отладки размещения текста и для просмотра размещения и насколько велика метка на самом деле.
9 ответов
Вы можете установить границу метки через лежащее в ее основе свойство CALayer:
#import <QuartzCore/QuartzCore.h>
myLabel.layer.borderColor = [UIColor greenColor].CGColor;
myLabel.layer.borderWidth = 3.0;
Вот некоторые вещи, которые вы можете сделать с UILabel
и его границы.
Вот код для этих меток:
import UIKit
class ViewController: UIViewController {
@IBOutlet weak var label1: UILabel!
@IBOutlet weak var label2: UILabel!
@IBOutlet weak var label3: UILabel!
@IBOutlet weak var label4: UILabel!
@IBOutlet weak var label5: UILabel!
@IBOutlet weak var label6: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
// label 1
label1.layer.borderWidth = 1.0
// label 2
label2.layer.borderWidth = 5.0
label2.layer.borderColor = UIColor.blue.cgColor
// label 3
label3.layer.borderWidth = 2.0
label3.layer.cornerRadius = 8
// label 4
label4.backgroundColor = UIColor.cyan
// label 5
label5.backgroundColor = UIColor.red
label5.layer.cornerRadius = 8
label5.layer.masksToBounds = true
// label 6
label6.layer.borderWidth = 2.0
label6.layer.cornerRadius = 8
label6.backgroundColor = UIColor.yellow
label6.layer.masksToBounds = true
}
}
Обратите внимание, что в Swift нет необходимости импортировать QuartzCore
,
Смотрите также
- Граница, закругленные углы и тень на
CALayer
- Объяснение
masksToBounds
- Использование границы с путем Безье для слоя
- Как сделать преобразования на
CALayer
Swift версия:
myLabel.layer.borderWidth = 0.5
myLabel.layer.borderColor = UIColor.greenColor().CGColor
Для Swift 3:
myLabel.layer.borderWidth = 0.5
myLabel.layer.borderColor = UIColor.green.cgColor
Swift 3/4 с @IBDesignable
Хотя почти все вышеперечисленные решения работают нормально, но я бы предложил @IBDesignable
пользовательский класс для этого.
@IBDesignable
class CustomLabel: UILabel {
/*
// Only override draw() if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
override func draw(_ rect: CGRect) {
// Drawing code
}
*/
@IBInspectable var borderColor: UIColor = UIColor.white {
didSet {
layer.borderColor = borderColor.cgColor
}
}
@IBInspectable var borderWidth: CGFloat = 2.0 {
didSet {
layer.borderWidth = borderWidth
}
}
@IBInspectable var cornerRadius: CGFloat = 0.0 {
didSet {
layer.cornerRadius = cornerRadius
}
}
}
Свойства UILabel borderColor,borderWidth,cornerRadius в Swift 4
@IBOutlet weak var anyLabel: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
anyLabel.layer.borderColor = UIColor.black.cgColor
anyLabel.layer.borderWidth = 2
anyLabel.layer.cornerRadius = 5
anyLabel.layer.masksToBounds = true
}
Вы можете использовать этот репо: GSBorderLabel
Все довольно просто:
GSBorderLabel *myLabel = [[GSBorderLabel alloc] initWithTextColor:aColor
andBorderColor:anotherColor
andBorderWidth:2];
Решение для Swift 4:
yourLabel.layer.borderColor = UIColor.green.cgColor
Использование строки NSAttributedString для ваших меток attributeText, вероятно, является лучшим выбором. Проверьте этот пример.
Это действительно зависит от того, сколько границ используется в вашем представлении, иногда просто добавьте UIVIEW, размер которого немного больше, чтобы создать границу. метод быстрее, чем создать представление