67

Still learning Swift and don't know Objective-C. I saw that in order to changing a button's text programmatically requires the use of titleEdgeInsets but I am not really sure how to use it.

I would like to change the text in the button (padding) in the bottom and both the left and the right.

Thanks for any responses and/or examples!

Mike Laren
  • 8,028
  • 17
  • 51
  • 70
KellysOnTop23
  • 1,325
  • 2
  • 15
  • 34

8 Answers8

172

Still valid for: iOS 12/Xcode 10/Swift 4.2/OSX 10.13.2


iOS 9.1/Xcode 7.1/Swift 2.1/OSX 10.10.5:

The method titleEdgeInsets didn't work for me. My button's frame tightly hugs the text (I didn't specify a frame size), and the frame has a red background color. After doing:

 myButton.titleEdgeInsets = UIEdgeInsetsMake(10,10,10,10)

the red background shrunk inwards by 10 pixels on each side, which meant that now some of the text was outside the red background. Using negative values had no effect on the original frame size.

I was able to get padding around the text, effectively making the frame bigger, by doing:

myButton.contentEdgeInsets = UIEdgeInsetsMake(5,5,5,5) 
7stud
  • 46,922
  • 14
  • 101
  • 127
64

iOS 10 and Swift 3 example

Tested and works on IOS 11 and Swift 4.

refineButton.contentEdgeInsets = UIEdgeInsets(top: 5, left: 0, bottom: 0, right: 0)
Ahmed Eid
  • 4,414
  • 3
  • 28
  • 34
Dev2rights
  • 3,469
  • 3
  • 25
  • 42
32

You can add padding from top, left, right and bottom by doing these lines of code.

button.titleEdgeInsets.left = 10; // add left padding.
button.titleEdgeInsets.right = 10; // add right padding.
button.titleEdgeInsets.top = 10; // add top padding.
button.titleEdgeInsets.bottom = 10; // add bottom padding.
Ahmad Baracat
  • 470
  • 5
  • 16
Ali Raza
  • 1,183
  • 1
  • 10
  • 15
27

You can also do this in the storyboard:
enter image description here

Nike Kov
  • 12,630
  • 8
  • 75
  • 122
6

For iOS 9.1/Xcode 7.1/Swift 2.1

@IBOutlet weak var ratingButton: UIButton!

override func viewDidLoad() {
    ratingButton.contentEdgeInsets = UIEdgeInsets(top:15,right:10,bottom:15,left:10)

    super.viewDidLoad()
}
Hannes
  • 2,451
  • 2
  • 18
  • 11
0

With iOS 15 contentEdgeInsets is deprecated so you need to use the following...

var configuration = UIButton.Configuration.plain() // there are several options to choose from instead of .plain()
configuration.contentInsets = NSDirectionalEdgeInsets(top: 24, leading: 24, bottom: 24, trailing: 24)
button.configuration = configuration
Oliver Pearmain
  • 19,885
  • 13
  • 86
  • 90
-1

Or you can use a custom class if you don't want to define the properties everytime you create a button;

class UIPaddedButton: UIButton {
  let padding = UIEdgeInsets(top: 0, left: 10, bottom: 0, right: 10)

  required init?(coder: NSCoder) {
    super.init(coder: coder)
  }

  override init(frame: CGRect) {
    super.init(frame: frame)
  }

  override func titleRect(forContentRect contentRect: CGRect) -> CGRect {
    return contentRect.inset(by: padding)
  }
}

And when initializing;

let btn = UIPaddedButton()
Ahmet Gokdayi
  • 301
  • 9
  • 14
  • 1
    this is **not really correct.** adjusting the titleRect is quite difficult. you have to follow a procedure similar to this: https://stackoverflow.com/a/58876988/294884 – Fattie Apr 17 '20 at 13:29
-2

For xcode 13.4 and iOS 12 Tested and working To make space to both sides of a button

ButtonName.contentEdgeInsets = UIEdgeInsets(top: 0, left: 20, bottom: 0, right: 20)
JESTIN SAJI
  • 53
  • 1
  • 15