มีวิธีสำหรับ UILabel ในการวาดเส้นขอบรอบตัวเองหรือไม่? สิ่งนี้มีประโยชน์สำหรับฉันในการดีบักตำแหน่งข้อความและเพื่อดูตำแหน่งและขนาดของป้ายกำกับที่แท้จริง
มีวิธีสำหรับ UILabel ในการวาดเส้นขอบรอบตัวเองหรือไม่? สิ่งนี้มีประโยชน์สำหรับฉันในการดีบักตำแหน่งข้อความและเพื่อดูตำแหน่งและขนาดของป้ายกำกับที่แท้จริง
คำตอบ:
คุณสามารถกำหนดขอบเขตของป้ายกำกับผ่านคุณสมบัติ CALayer ที่อยู่ภายใน:
#import <QuartzCore/QuartzCore.h>
myLabel.layer.borderColor = [UIColor greenColor].CGColor
myLabel.layer.borderWidth = 3.0
สวิฟท์ 5:
myLabel.layer.borderColor = UIColor.darkGray.cgColor
myLabel.layer.borderWidth = 3.0
#import <QuartzCore/QuartzCore.h>
myLabel.layer.borderColor = UIColor.greenColor().CGColor
นี่คือบางสิ่งที่คุณสามารถทำได้ด้วย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
}
}
QuartzCore
โปรดสังเกตว่าในสวิฟท์มีความจำเป็นต้องนำเข้าไม่มี
ดูสิ่งนี้ด้วย
รุ่น 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
myLabel.layer.borderColor = UIColor.blackColor().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
}
}
}
คุณสามารถใช้ repo นี้: GSBorderLabel
มันค่อนข้างง่าย:
GSBorderLabel *myLabel = [[GSBorderLabel alloc] initWithTextColor:aColor
andBorderColor:anotherColor
andBorderWidth:2];
คุณสมบัติของ 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
}
โซลูชันสำหรับ Swift 4:
yourLabel.layer.borderColor = UIColor.green.cgColor
มันขึ้นอยู่กับจำนวนนักเรียนที่ใช้ประจำในมุมมองของคุณบางครั้งเพียงเพิ่ม UIVIEW ซึ่งขนาดใหญ่ขึ้นเล็กน้อยเพื่อสร้างเส้นขอบ วิธีนี้เร็วกว่าการสร้างมุมมอง
การใช้สตริง NSAttributedString สำหรับป้ายกำกับของคุณ ลองดูตัวอย่างนี้