20

Is there a way to set the starting selected segment in a UISegmentedControl in Interface Builder, or do I have to do it in the code? If it's in the code, is viewDidLoad the best place to set it?

Swift Dev Journal
  • 19,282
  • 4
  • 56
  • 66
nevan king
  • 112,709
  • 45
  • 203
  • 241

6 Answers6

42

From code, you can do:

self.segmentedControl.selectedSegmentIndex = someDefaultIndex

Whether you should set it in viewDidLoad: or not depends entirely on the structure of your application. For example, if your app is starting up and loading the view for the first time and needs to set the control to whatever value it had during the previous run of the app, then it definitely makes sense to do it there.

pkamb
  • 33,281
  • 23
  • 160
  • 191
drewh
  • 10,077
  • 7
  • 34
  • 43
  • What about a rule to override the "selected" answer when the popular vote gets to 2X (or a defined multiplier) of the "accepted" vote count? – eharo2 Jun 18 '19 at 16:48
20

In Interface Builder when you select UISegmentedControl object on your UI, then in attributes pane, in segment control there's segment drop down menu, select segment that you want selected (0,1 and so on) and tick the 'selected' option below it.

stefanB
  • 77,323
  • 27
  • 116
  • 141
3

Select default value for your UISegmentedControl via storyBoard

  1. Open ur storyboard and select the UISegmentedControl

enter image description here

  1. Select atributes inspector of your UISegmentedControl (in the right corner)

enter image description here

  1. Search the 'segment' atribute and open de dropdown.

enter image description here

  1. Select the item you want to be selected by default.

enter image description here

  1. Mark the selected checkbox to set selected by default.

enter image description here

Iker Solozabal
  • 1,232
  • 11
  • 16
0

If you don't use storyboards and want to set a default index after some setup/networking like me, this little snippet will select something if the user hasn't. I placed this in my subclass of UISegmentedControl, but you could place this anywhere. (Swift 3)

Decl: var UISegmentedControlNoSegment: Int { get }
Desc: A segment index value indicating that there is no selected segment. See selectedSegmentIndex for further information.

Short version:

if selectedSegmentIndex == UISegmentedControlNoSegment {
    selectedSegmentIndex = initialIndex
}

Longer version

func reloadData() {
    guard let numberOfItems = dataSource?.numberOfItems() else {
        return
    }

    removeAllSegments()

    for index in 0...numberOfItems {
        insertSegment(with: $image, at: index, animated: false)
    }

    if selectedSegmentIndex == UISegmentedControlNoSegment {
        selectedSegmentIndex = initialIndex
    }
}
Oscar Apeland
  • 6,422
  • 7
  • 44
  • 92
0

After clicking the Segmented Control go to where you created the segments and choose the one you want be default. Then below that there will be a Box with "Selected" by it. Select that and it will be default.

0

If the UISegmentedControl in UI still looks like unselected (UISegmentedControlNoSegment) after initial selection

segmentedControl.selectedSegmentIndex = 0

Seem is the case when the UISegmentedControl is created programmatically, try additionally send valueChanged action

// Swift
segmentedControl.selectedSegmentIndex = 0
segmentedControl.sendActions(for: .valueChanged)

// ObjC
segmentedControl.selectedSegmentIndex = 0;
[segmentedControl sendActionsForControlEvents:UIControlEventValueChanged];

to update it in the UI or to properly update another UI that is bound to the UISegmentedControl state

Source: How do I switch UISegmentedControl programmatically?

CAHbl463
  • 102
  • 7