UISegmentedControl用于管理和实现一组内容的切换,主要用于导航栏的标题视图。
添加以下代码即可实现主要功能。
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
//设置分页控件的各个tab的title
let seg = UISegmentedControl(items:["oneeirodfdsfdsfdsfdfdgdsgdgdgdsg","","three","four"])
//设置分页控件的位置和大小
seg.frame = CGRect(x:20, y:100, width:320, height:30)
//设置分页控件中第二个tab的title位置显示图片
seg.setImage(UIImage(named:"2")?.withRenderingMode(.alwaysOriginal),forSegmentAt:1)
//设置内容和tab的偏移
seg.setContentOffset(CGSize(width:0,height:0), forSegmentAt: 1)
//设置是否为button模式,true 点击tab后高亮显示->消失,false 点击tab后高亮一直显示,直到点击下一个tab
seg.isMomentary = true
self.view.addSubview(seg)
//在现有的分页控件中加入tab
seg.insertSegment(withTitle:"new", at: 2, animated: true)
//在现有的分页控件中移除tab
seg.removeSegment(at: 4, animated: true)
//修改tab的文字内容,如果之前tab显示的是图片的话,图片也会变成修改后的文字
seg.setTitle("replace", forSegmentAt: 1)
//设置某一个tab的宽度,不设置的情况下,tab是等宽的
seg.setWidth(50, forSegmentAt: 0)
//设置tab的宽度根据内容自适应,如果某个tab内容过长,系统会显示完能显示tab的内容后,过长的tab的文字最后还是会显示...
//另外,同时设置了setWidth和此属性的情况下,系统会优先setWidth的设置
seg.apportionsSegmentWidthsByContent = true
//删除所有tab的内容
seg.removeAllSegments()
}
UISegmentedControl添加触发方法也是通过addTarget方法设置的,需要监听的触发动作和UIPageControl控件一致,为valueChanged。