如何在UILabel周围画边框?

时间:2010-02-22 14:49:49

标签: ios iphone cocoa-touch uikit uilabel

UILabel有没有办法在自己周围画一个边框?这对我调试文本位置和查看位置以及标签的实际大小非常有用。

9 个答案:

答案 0 :(得分:248)

您可以通过其基础CALayer属性设置标签的边框:

#import <QuartzCore/QuartzCore.h>

myLabel.layer.borderColor = [UIColor greenColor].CGColor;
myLabel.layer.borderWidth = 3.0;

答案 1 :(得分:67)

您可以使用UILabel及其边框执行以下操作。

enter image description here

以下是这些标签的代码:

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

另见

答案 2 :(得分:17)

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

答案 3 :(得分:4)

使用@IBDesignable快速3/4

虽然上述几乎所有解决方案都能正常运行,但我建议使用@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
        }
    }
}

答案 4 :(得分:2)

您可以使用此回购:GSBorderLabel

这很简单:

GSBorderLabel *myLabel = [[GSBorderLabel alloc] initWithTextColor:aColor
                                                     andBorderColor:anotherColor
                                                     andBorderWidth:2];

答案 5 :(得分:1)

UILabel属性borderColor,borderWidth,在Swift 4中的cornerRadius

@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
}

答案 6 :(得分:1)

Swift 4解决方案:

yourLabel.layer.borderColor = UIColor.green.cgColor

答案 7 :(得分:0)

这实际上取决于视图中使用了多少寄存器,有时只需添加一个大小稍大的UIVIEW来创建边框。该方法比生成视图更快

答案 8 :(得分:0)

为您的标签使用NSAttributedString字符串referencedText可能是您最好的选择。 Check out this example.