How to add Padding in UILabel in iOS using Swift

In this tutorial, I’m going to show how to add padding in UILabel using Swift without needed any third-party library.

On the Internet, many people suggest using UITextView to be able to have padding in your text, because iOS doesn’t support padding in UILabel.

Today, I’ll show you an easy way to have padding in UILabel too!

Adding Padding Support in UILabel

First, create a new swift file and name it PaddingLabel

Then, paste the following code inside:

import Foundation import UIKit @IBDesignable class PaddingLabel: UILabel { var textEdgeInsets = { didSet { invalidateIntrinsicContentSize() } } open override func textRect(forBounds bounds: CGRect, limitedToNumberOfLines numberOfLines: Int) -> CGRect { let insetRect = bounds.inset(by: textEdgeInsets) let textRect = super.textRect(forBounds: insetRect, limitedToNumberOfLines: numberOfLines) let invertedInsets = UIEdgeInsets(top:, left: -textEdgeInsets.left, bottom: -textEdgeInsets.bottom, right: -textEdgeInsets.right) return textRect.inset(by: invertedInsets) } override func drawText(in rect: CGRect) { super.drawText(in: rect.inset(by: textEdgeInsets)) } @IBInspectable var paddingLeft: CGFloat { set { textEdgeInsets.left = newValue } get { return textEdgeInsets.left } } @IBInspectable var paddingRight: CGFloat { set { textEdgeInsets.right = newValue } get { return textEdgeInsets.right } } @IBInspectable var paddingTop: CGFloat { set { = newValue } get { return } } @IBInspectable var paddingBottom: CGFloat { set { textEdgeInsets.bottom = newValue } get { return textEdgeInsets.bottom } } }
Code language: Swift (swift)

Using Padding in UILabel


If you’re using storyboards, after you have added the label in your view, add the PaddingLabel class as a Custom Class

Next, select the Attribute Inspector and add the padding:


If you have created an UILabel programmatically, replace the UILabel class with the PaddingLabel and add the padding:

// Init Label let label = PaddingLabel() label.backgroundColor = .black label.textColor = .white label.font = .systemFont(ofSize: 26, weight: .semibold) label.text = "UILabel with Padding" self.view.addSubview(label) // Padding label.paddingLeft = 15 label.paddingRight = 15 label.paddingTop = 8 label.paddingBottom = 8 // ...
Code language: Swift (swift)
You can find the final project here

If you have any questionsplease feel free to leave a comment below

Notify of
Newest Most Voted
Inline Feedbacks
View all comments

thanks dude. very clear


Wow, this really works, and so far no unanticipated consequences! Thanks so much, improved the visual appeal of my project a lot.