3

Before asking the question, I have searched stackoverflow, find a related post:

change segmentControl border color

But we can see it is in objective-c language.

So how can we change the borderColor of UISegmentControl in swift ?

aircraft
  • 25,146
  • 28
  • 91
  • 166

5 Answers5

3

More simple approach:

segmentControl.layer.borderWidth = 1.0
segmentControl.layer.cornerRadius = 5.0
segmentControl.layer.borderColor = UIColor.red.cgColor
segmentControl.layer.masksToBounds = true
Tiago Mendes
  • 4,572
  • 1
  • 29
  • 35
1

You literally just have to convert the code to swift...

let customSegmentedControl = UISegmentedControl.appearance()    
customSegmentedControl.setTitleTextAttributes([NSForegroundColorAttributeName : UIColor.red], for: UIControlState.normal)

But I believe the code you posted changes the actual color of the letters, not the color outside. The color outside is called "tint" and it's changed like this:

customSegmentedControl.tintColor = UIColor.blue

EDIT: For ONLY changing the border

Since each segment in the SegmentedControl is an actual UIView you can access them directly and customize them per your needs as in this answer.

Or you can set the "background image" which I believe can be set to the color you need. (Although the method above seems less complicated)

Community
  • 1
  • 1
Pochi
  • 13,391
  • 3
  • 64
  • 104
1

Add the outlet

@IBOutlet weak var customSegment: UISegmentedControl!

then in your viewDidload method

    customSegment.layer.borderWidth = 1.0
    customSegment.layer.cornerRadius = 5.0
    customSegment.layer.borderColor = UIColor.red.cgColor
    customSegment.layer.masksToBounds = true

enter image description here

Chathuranga
  • 316
  • 4
  • 12
0

We can set the background image to achieve the effect.

    let customSegmentedControl = UISegmentedControl.appearance()
    //customSegmentedControl.setTitleTextAttributes([NSForegroundColorAttributeName : UIColor.red], for: UIControlState.normal)

    customSegmentedControl.setBackgroundImage(UIImage.init(named: "ni2.png"), for: .normal, barMetrics: .default)
    customSegmentedControl.setBackgroundImage(UIImage.init(named: "ni.png"), for: .selected, barMetrics: .default)
aircraft
  • 25,146
  • 28
  • 91
  • 166
-1
self.segementControl.layer.borderWidth = 0.3
self.segementControl.layer.cornerRadius = 3.0
self.segementControl.layer.borderColor = UIColor.orange.cgColor
Haya Hashmat
  • 137
  • 10