中关村村草 发表于 2012-03-05 20:16

UISegmentedControl 分段控件-IOS开发

UISegmentedControl 分段控件-IOS开发











UISegmentedControl分段控件代替了桌面OS上的单选按钮。不过它的选项个数非常有限,因为你的IOS设备屏幕有限。当我们需要使用选项非常少的单选按钮时它很合适。

一、创建

UISegmentedControl* mySegmentedControl = [initWithItems:nil];

是不是很奇怪没有指定位置和大小呢?没错,我确实在他的类声明里只找到 initWithItems 而未找到 initWithFrame ,所以他不需要指定,不过我看到了另一个方法,这个方法可以设置Item的宽度:01.mySegmentedControl setWidth:100 forSegmentAtIndex:0];//设置Item的宽度
复制代码二、属性01.mySegmentedControl.segmentedControlStyle = UISegmentedControlStyleBar;//风格
复制代码可以视使用的场合,有三种风格选择,如下:01.typedef enum {

02.    UISegmentedControlStylePlain,   // large plain 有灰边的大白按钮,适合偏好设置单元

03.    UISegmentedControlStyleBordered,// large bordered 黑边的大白按钮,适用于表格单元

04.    UISegmentedControlStyleBar,       // small button/nav bar style. tintable 小按钮,适合导航栏

05.    UISegmentedControlStyleBezeled,   // large bezeled style. tintable

06.} UISegmentedControlStyle;
复制代码如果你使用的是 UISegmentedControlStyleBar 风格,还可以用空间的 tintColor 属性为整个控件设置渲染色彩:01.UIColor *myTint = [[ UIColor alloc]initWithRed:0.66 green:1.0 blue:0.77 alpha:1.0];

02.   mySegmentedControl.tintColor = myTint;
复制代码三、添加、删除片段每个分段控件的片段都是一个按钮,其中包含一个标签或图片。你需要在你的控件中为每个控件创建一个片段。只要屏幕放得下,就可以有许多片段,但用户同一时刻只能选择一个片段。01.;

02.    ;
复制代码每个
按钮都被赋予一个索引,用这个索排序以及标识。
你也可以添加一个含有图像的片段,用inserSegmentWithImage01.atIndex:3 animated:YES];
复制代码删除片段01.;//删除一个片段

02.    ;//删除所有片段
复制代码四、片段标题01.;//设置标题

02.    NSString* myTitle = ;//读取标题
复制代码五、图像每个分段也可以设置图像:01. forSegmentAtIndex:1];//设置

02.    UIImage* myImage = ;//读取
复制代码注意:图像不会自动调整大小,图片多大就会原生地显示多大,所以你要通知做图的美工大小要精确。
六、选中分段分段控件的默认行为是,一旦按钮被选中就一直保持,直到另外一个按钮被选中为止。你可以改变这种默认的行为,变成按钮按下后很快就自动释放。将控件的momentary属性设为YES:01.mySegmentedControl.momentary = YES;
复制代码注意:开启这个功能后点触片段不会更新 selectedSegmentedIndex,因此也就无法通过这个属性得到当前选取的片段。初始化默认片段默认情况下,除非你指定,否则不会有任何片段被选中。要设置 selectedSegmentedIndex 属性:01.mySegmentedControl.selectedSegmentedIndex = 0;
复制代码七、显示控件01.;//添加到父视图

02.   或

03.   self.navigationItem.titleView = mySegmentedControl;//添加到导航栏
复制代码八、读取控件通过 selectedSegmentedIndex 属性,可以读取当前选中分段的值,这个值就是选中片段的索引号。01.int x = mySegmentedControl. selectedSegmentedIndex;
复制代码九、通知要接收片段选取的通知,可以用UIControl类的 addTarget 方法,为 UIControlEventValueChanged 事件添加一个动作:01.;
复制代码只要选中了一个片段,你的动作方法就会被调用:01.-(void)selected:(id)sender{

02.    UISegmentedControl* control = (UISegmentedControl*)sender;

03.    switch (control.selectedSegmentIndex) {

04.      case 0:

05.            //

06.            break;

07.      case 1:

08.            //

09.            break;

10.      case 2:

11.            //

12.            break;

13.            

14.      default:

15.            break;

16.    }

17.}
复制代码十、Demo最后附上我边写文章,边测试用的Demo:

我是软件狂 发表于 2012-03-05 20:16

谢谢分享

liangmian1 发表于 2014-07-01 16:54

不错的控件教程

bokezyyx 发表于 2014-07-09 17:08

真心赞的控件知识分享
页: [1]
查看完整版本: UISegmentedControl 分段控件-IOS开发