UISegmentedControl分段控件代替了桌面OS上的单选按钮。不过它的选项个数非常有限,因为你的IOS设备屏幕有限。当我们需要使用选项非常少的单选按钮时它很合适。
一、创建
UISegmentedControl* mySegmentedControl = [[UISegmentedControl alloc]initWithItems:nil];
是不是很奇怪没有指定位置和大小呢?没错,我确实在他的类声明里只找到 initWithItems 而未找到 initWithFrame ,所以他不需要指定,不过我看到了另一个方法,这个方法可以设置Item的宽度:
mySegmentedControl setWidth:100 forSegmentAtIndex:0];//设置Item的宽度
二、属性
mySegmentedControl.segmentedControlStyle = UISegmentedControlStyleBar;//风格
可以视使用的场合,有三种风格选择,如下:
typedef enum {
UISegmentedControlStylePlain, // large plain 有灰边的大白按钮,适合偏好设置单元
UISegmentedControlStyleBordered, // large bordered 黑边的大白按钮,适用于表格单元
UISegmentedControlStyleBar, // small button/nav bar style. tintable 小按钮,适合导航栏
UISegmentedControlStyleBezeled, // large bezeled style. tintable
} UISegmentedControlStyle;
如果你使用的是 UISegmentedControlStyleBar 风格,还可以用空间的 tintColor 属性为整个控件设置渲染色彩:
UIColor *myTint = [[ UIColor alloc]initWithRed:0.66 green:1.0 blue:0.77 alpha:1.0];
mySegmentedControl.tintColor = myTint;
三、添加、删除片段每个分段控件的片段都是一个按钮,其中包含一个标签或图片。你需要在你的控件中为每个控件创建一个片段。只要屏幕放得下,就可以有许多片段,但用户同一时刻只能选择一个片段。
[mySegmentedControl insertSegmentWithTitle:@"First" atIndex:0 animated:YES];
[mySegmentedControl insertSegmentWithTitle:@"Second" atIndex:2 animated:YES];
每个
按钮都被赋予一个索引,用这个索排序以及标识。
你也可以添加一个含有图像的片段,用inserSegmentWithImage
[mySegmentedControl insertSegmentWithImage:[UIImage imageNamed:@"pic"] atIndex:3 animated:YES];
删除片段
[mySegmentedControl removeSegmentAtIndex:0 animated:YES];//删除一个片段
[mySegmentedControl removeAllSegments];//删除所有片段
四、片段标题
[mySegmentedControl setTitle:@"ZERO" forSegmentAtIndex:0];//设置标题
NSString* myTitle = [mySegmentedControl titleForSegmentAtIndex:1];//读取标题
五、图像每个分段也可以设置图像:
[mySegmentedControl setImage:[UIImage imageNamed:@"pic"] forSegmentAtIndex:1];//设置
UIImage* myImage = [mySegmentedControl imageForSegmentAtIndex:2];//读取
注意:图像不会自动调整大小,图片多大就会原生地显示多大,所以你要通知做图的美工大小要精确。
六、选中分段分段控件的默认行为是,一旦按钮被选中就一直保持,直到另外一个按钮被选中为止。你可以改变这种默认的行为,变成按钮按下后很快就自动释放。将控件的momentary属性设为YES:
mySegmentedControl.momentary = YES;
注意:开启这个功能后点触片段不会更新 selectedSegmentedIndex,因此也就无法通过这个属性得到当前选取的片段。初始化默认片段默认情况下,除非你指定,否则不会有任何片段被选中。要设置 selectedSegmentedIndex 属性:
mySegmentedControl.selectedSegmentedIndex = 0;
七、显示控件
[parentView addSubview:mySegmentedControl];//添加到父视图
或
self.navigationItem.titleView = mySegmentedControl;//添加到导航栏
八、读取控件通过 selectedSegmentedIndex 属性,可以读取当前选中分段的值,这个值就是选中片段的索引号。
int x = mySegmentedControl. selectedSegmentedIndex;
九、通知要接收片段选取的通知,可以用UIControl类的 addTarget 方法,为 UIControlEventValueChanged 事件添加一个动作:
[mySegmentedControl addTarget:self action:@selector(selected:) forControlEvents:UIControlEventValueChanged];
只要选中了一个片段,你的动作方法就会被调用:
-(void)selected:(id)sender{
UISegmentedControl* control = (UISegmentedControl*)sender;
switch (control.selectedSegmentIndex) {
case 0:
//
break;
case 1:
//
break;
case 2:
//
break;
default:
break;
}
}
分享到:
相关推荐
Android仿iOS7的UISegmentedControl 分段
UISegmentedControl分段控件代替了桌面OS上的单选按钮。不过它的选项个数非常有限,因为你的IOS设备屏幕有限。当我们需要使用选项非常少的单选按钮时它很合适。 一、创建 代码如下: UISegmentedControl* ...
iphone中的基础控件UISegmentedControl,适合初学者,主要学习UISegmentedControl的常用属性设置、点击事件、分段控制器,每一个按钮都有自己独立的功能,其数据源是一般是数组等
SNFSegmentedViewController是使用UISegmentedControl在视图控制器之间进行切换的最简单方法。 您不必担心视图控制器的约束或设置大量的自定义空序列。 SNFSegmentedViewController可以正常工作。 用法 由于...
源码android-segmented-control-view,在ios7中有一种扁平风格的控件叫做分段选择控件UISegmentedControl,控件分为一排,横放着几个被简单线条隔开的按钮,每次点击只能选择其中一个按钮,他类似于tabbar但是又稍微...
HMS分段控制 UISegmentedControl的高度可定制的替代产品,已被22,...用法下面的代码将创建具有默认外观的分段控件: let segmentedControl = HMSegmentedControl ( sectionTitles : [ " Trending " , " News " , " Li
可用作分段控件或开关 可自定义选项的Plethora,从颜色到插图,半径和动画 使用文本或图标作为细分,或添加自己的自定义细分 直接在Interface Builder中设计 辅助功能支持 iPad光标支持 可自定义的行为 从右...
MultiSelectSegmentedControl UISegmentedControl重制,它支持选择多个段,垂直堆叠,组合文本和图像。特征 单选或多选。 水平或垂直堆叠。 可以同时显示文本和图像。 从情节提要或代码中使用。 UIAppearance支持。...
很类似地模仿了Google Currents和其他谷歌产品的的分段控件效果的。功能支持文本和图片支持水平滚动支持字体和颜色的自定义支持顶端和底部的分段指示支持blocks支持ARCA drop-in replacement for UISegmentedControl...
利用 UISegmentedControl 实现的滑块儿 Tab 效果.zip,iOS的自定义uisegmentedcontrol替换,用swift编写
我们希望在我们的应用程序中使用新的分段控件,但是本机组件SegmentedControlIOS出现了一些问题。 新设计仅在iOS 13及更高版本上可用-告别旧版本的应用程序支持。 该组件不是完全可定制的。 没有适用于Android的...
该源码实现支持自定义分段控件的效果,可以随便自定义UISegmentedControl的文字和颜色,以及图片等,另外还可以给Segment加上图片等,值得大家的学习,。
UISegmentedControl Demo代码,单选栏
UISegmentedControl轻松使用
TOSegmentedControl 作为iOS 13的视觉改进的一部分, UISegmentedControl进行了完全重新设计,具有更加圆润,整洁和略微拟人化的外观。 TOSegmentedControl是UIControl的子类,它完全重新实现了新的...
自定义UISegmentedControl空间
自定义UISegmentedControl,源代码地址:https://github.com/STShenZhaoliang/STKitSwift
基于用Objective-C编写的UISwitch和UISegmentedControl的可定制控件 DVSwitch 的灵感来自 UISwitch 和 UISegmentedControl。 这段代码的目标是: 易于自定义的控件,带有漂亮的动画 支持平移或滑动交互 需要很少的...
android仿ios的segmentedcontrol