前言
對應(yīng)一個(gè)曾經(jīng)開發(fā) Android 的人來說,沒有這些基礎(chǔ)屬性簡直令人發(fā)指,還是表噴這個(gè),認(rèn)真寫代碼 - - #
正文
代碼實(shí)現(xiàn):
class UILabelPadding : UILabel { private var padding = UIEdgeInsetsZero @IBInspectable var paddingLeft: CGFloat { get { return padding.left } set { padding.left = newValue } } @IBInspectable var paddingRight: CGFloat { get { return padding.right } set { padding.right = newValue } } @IBInspectable var paddingTop: CGFloat { get { return padding.top } set { padding.top = newValue } } @IBInspectable var paddingBottom: CGFloat { get { return padding.bottom } set { padding.bottom = newValue } } override func drawTextInRect(rect: CGRect) { super.drawTextInRect(UIEdgeInsetsInsetRect(rect, padding)) } override func textRectForBounds(bounds: CGRect, limitedToNumberOfLines numberOfLines: Int) -> CGRect { let insets = self.padding var rect = super.textRectForBounds(UIEdgeInsetsInsetRect(bounds, insets), limitedToNumberOfLines: numberOfLines) rect.origin.x -= insets.left rect.origin.y -= insets.top rect.size.width += (insets.left + insets.right) rect.size.height += (insets.top + insets.bottom) return rect }}
代碼說明:
通過 IBInspectable 可以支持 UILable 在 Storyboard 里面就能指定內(nèi)邊距,非常方便:
以上就是Swift UILable 設(shè)置內(nèi)邊距實(shí)例代碼,開發(fā)IOS應(yīng)用需要用的可以參考下。
新聞熱點(diǎn)
疑難解答
圖片精選