初始化UISegmentedControl
NSArray *arr = [[NSArray alloc]initWithObjects:@"轻拍",@"长按",@"清扫",@"旋转",@"捏合",@"拖拽", nil];
//先创建一个数组用于设置标题
UISegmentedControl *segment = [[UISegmentedControl alloc]initWithItems:arr];
//在没有设置[segment setApportionsSegmentWidt
hsByContent:YES]时,每个的宽度按segment的宽度平分 segment.frame = CGRectMake(0, 400, 320, 40);
//设置frame
管理Segment的内容
[segment setTitle:@"大便" forSegmentAtIndex:3];
//设置下标为3的segment的标题 下标以0开始 IOS里的所有下标都是以0开始
[segment setImage:[UIImage imageNamed:@"3"] forSegmentAtIndex:4];
//设置下标为4的segment的图片
管理Segments
[segment insertSegmentWithImage:[UIImage imageNamed:@"3"] atIndex:2 animated:YES];
//设置图片
[segment insertSegmentWithTitle:@"ddd" atIndex:0 animated:YES];//设置标题
[segment numberOfSegments];//得到segment的数量
[segment removeAllSegments];//移出所有segment
[segment removeSegmentAtIndex:2 animated:YES];//移出下标为2的segment
segment.selectedSegmentIndex = 0;//选中第几个segment 一般用于初始化时选中
管理Segment的行为和外观
segment.momentary = NO;
//默认为NO 当设置为YES时,当被选中后,一会儿后不显示被选中状态(最左边的样子),不选中状态即下图的右边几个按钮一样
segment.segmentedControlStyle = UISegmentedControlStyleB
ar; typedef enum {
UISegmentedControlStyleP lain,
UISegmentedControlStyleB ordered,
UISegmentedControlStyleB ar,
UISegmentedControlStyleB ezeled,
} UISegmentedControlStyle;
//设置样式 当为Bordered和Bar时tintColor才有效 下图为tintcolor为红色时的样子
//Bar样式
//Bordered
[segment setEnabled:NO];
//设置segment是否可用 此方法是其父类UIControl的方法
[segment setEnabled:NO forSegmentAtIndex:2];//设置下标为2的segment不可用
[segment setWidth:100 forSegmentAtIndex:2];
//这时下表为2的segment的宽度 [segment setContentOffset:CGSizeMake(10, 10) forSegmentAtIndex:2];//设置内容偏移
segment.apportionsSegmentWidthsB
yContent = YES; //是否根据segment的内容改变segment的宽度
自定义外观[segment setTintColor:[UIColor redColor]];
//设置segments的颜色
[segment setBackgroundImage:[UIImage imageNamed:@""] forState:UIControlStateNormal barMetrics:UIBarMetricsDefault];
typedef enum {
UIBarMetricsDefault, //竖屏
UIBarMetricsLandscapePho ne, 横屏
} UIBarMetrics;
//设置在某个状态下segments的背景图片
[segment setTitleTextAttributes:dic forState:UIControlStateNormal];
NSString *const UITextAttributeFont;value: UIFont
NSString *const UITextAttributeTextColor; value: UIColor
NSString *const UITextAttributeTextShadowColor; value: UIColor
NSString *const UITextAttributeTextShadowOffset; value: NSValue wrapping a UIOffset
NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:[UIColor redColor],UITextAttributeTextColor ,[UIFont fontWithName:@"SnellRoundhand-Bold" size:24],UITextAttributeFont ,nil]; //设置标题的颜色 字体和大小 阴影和阴影颜色
[segment addTarget:self action:@selector(change:) forControlEvents:UIControlEventValueChang
ed]; //当选中不同的segment时,会执行change:方法
UISegmentedControl分段控件代替了桌面OS上的单选按钮。不过它的选项个数非常有限,因为你的IOS设备屏幕有限。当我们需要使用选项非常少的单选按钮时它很合适。
一、创建
UISegmentedControl*mySegmentedControl = [[UISegmentedControlalloc]initWithItems:nil];
是不是很奇怪没有指定位置和大小呢?没错,我确实在他的类声明里只找到 initWithItems 而未找到 initWithFrame ,所以他不需要指定,不过我看到了另一个方法,这个方法可以设置Item的宽度:
- mySegmentedControl
setWidth:100 forSegmentAtIndex:0];//设置Item的宽度
二、属性
可以视使用的场合,有三种风格选择,如下:
- mySegmentedControl.segmentedControlStyle
= UISegmentedControlStyleB ar;//风格 如果你使用的是
- typedef
enum { UISegmentedControlStyleP lain, // large plain 有灰边的大白按钮,适合偏好设置单元 UISegmentedControlStyleB ordered, // large bordered 黑边的大白按钮,适用于表格单元 UISegmentedControlStyleB ar, // small button/nav bar style. tintable 小按钮,适合导航栏 UISegmentedControlStyleB ezeled, // large bezeled style. tintable - }
UISegmentedControlStyle; UISegmentedControlStyleB ar 风格,还可以用空间的 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:
注意:开启这个功能后点触片段不会更新 selectedSegmentedIndex,因此也就无法通过这个属性得到当前选取的片段。
- mySegmentedControl.momentary
= YES;
初始化默认片段
默认情况下,除非你指定,否则不会有任何片段被选中。要设置
selectedSegmentedIndex 属性: 七、显示控件
- mySegmentedControl.selectedSegmentedIndex
= 0; 八、读取控件
- [parentView
addSubview:mySegmentedControl];//添加到父视图 或 self.navigationItem.titleView = mySegmentedControl;//添加到导航栏
通过
selectedSegmentedIndex 属性,可以读取当前选中分段的值,这个值就是选中片段的索引号。 九、通知
- int
x = mySegmentedControl. selectedSegmentedIndex;
要接收片段选取的通知,可以用UIControl类的 addTarget 方法,为 UIControlEventValueChang
ed 事件添加一个动作: 只要选中了一个片段,你的动作方法就会被调用:
- [mySegmentedControl
addTarget:self action:@selector(selected:) forControlEvents:UIControlEventValueChang ed];
- -(void)selected:(id)sender{
UISegmentedControl* control = (UISegmentedControl*)sender; switch (control.selectedSegmentIndex) { case 0: // break; case 1: // break; case 2: // break; default: break; } - }
UISegmentedControl
最新推荐文章于 2017-05-16 14:07:42 发布