zoukankan      html  css  js  c++  java
  • UISegmentedControl 控件

    一、创建

    UISegmentedControl* mySegmentedControl = [[UISegmentedControl alloc]initWithItems:nil];

    是不是很奇怪没有指定位置和大小呢?没错,我确实在他的类声明里只找到 initWithItems 而未找到 initWithFrame ,所以他不需要指定,不过我看到了另一个方法,这个方法可以设置Item的宽度:

    1. mySegmentedControl setWidth:100 forSegmentAtIndex:0];//设置Item的宽度  

    、属性

    1. mySegmentedControl.segmentedControlStyle = UISegmentedControlStyleBar;//风格  

    可以视使用的场合,有三种风格选择,如下:

    1. typedef enum {  
    2.     UISegmentedControlStylePlain,     // large plain 有灰边的大白按钮,适合偏好设置单元   
    3.     UISegmentedControlStyleBordered,  // large bordered 黑边的大白按钮,适用于表格单元   
    4.     UISegmentedControlStyleBar,       // small button/nav bar style. tintable 小按钮,适合导航栏   
    5.     UISegmentedControlStyleBezeled,   // large bezeled style. tintable   
    6. } UISegmentedControlStyle;  

    如果你使用的是 UISegmentedControlStyleBar 风格,还可以用空间的 tintColor 属性为整个控件设置渲染色彩:

    1. UIColor *myTint = [[ UIColor alloc]initWithRed:0.66 green:1.0 blue:0.77 alpha:1.0];  
    2.    mySegmentedControl.tintColor = myTint;  

    三、添加、删除片段

    每个分段控件的片段都是一个按钮,其中包含一个标签或图片。你需要在你的控件中为每个控件创建一个片段。只要屏幕放得下,就可以有许多片段,但用户同一时刻只能选择一个片段。

    1. [mySegmentedControl insertSegmentWithTitle:@"First" atIndex:0 animated:YES];  
    2.     [mySegmentedControl insertSegmentWithTitle:@"Second" atIndex:2 animated:YES];  

    每个
    按钮都被赋予一个索引,用这个索排序以及标识。
    你也可以添加一个含有图像的片段,用inserSegmentWithImage

    1. [mySegmentedControl insertSegmentWithImage:[UIImage imageNamed:@"pic"]  atIndex:3 animated:YES];  

    删除片段

    1. [mySegmentedControl removeSegmentAtIndex:0 animated:YES];//删除一个片段   
    2.     [mySegmentedControl removeAllSegments];//删除所有片段  

    四、片段标题

    1. [mySegmentedControl setTitle:@"ZERO" forSegmentAtIndex:0];//设置标题   
    2.     NSString* myTitle = [mySegmentedControl titleForSegmentAtIndex:1];//读取标题  

    五、图像

    每个分段也可以设置图像:

    1. [mySegmentedControl setImage:[UIImage imageNamed:@"pic"] forSegmentAtIndex:1];//设置   
    2.     UIImage* myImage = [mySegmentedControl imageForSegmentAtIndex:2];//读取  

    注意:图像不会自动调整大小,图片多大就会原生地显示多大,所以你要通知做图的美工大小要精确。
    六、选中分段

    分段控件的默认行为是,一旦按钮被选中就一直保持,直到另外一个按钮被选中为止。你可以改变这种默认的行为,变成按钮按下后很快就自动释放。将控件的momentary属性设为YES:

    1. mySegmentedControl.momentary = YES;  

    注意:开启这个功能后点触片段不会更新 selectedSegmentedIndex,因此也就无法通过这个属性得到当前选取的片段。

    初始化默认片段

    默认情况下,除非你指定,否则不会有任何片段被选中。要设置 selectedSegmentedIndex 属性:

    1. mySegmentedControl.selectedSegmentedIndex = 0;  

    七、显示控件

    1. [parentView addSubview:mySegmentedControl];//添加到父视图   
    2.    或  
    3.    self.navigationItem.titleView = mySegmentedControl;//添加到导航栏  

    八、读取控件

    通过 selectedSegmentedIndex 属性,可以读取当前选中分段的值,这个值就是选中片段的索引号。

    1. int x = mySegmentedControl. selectedSegmentedIndex;  

    九、通知

    要接收片段选取的通知,可以用UIControl类的 addTarget 方法,为 UIControlEventValueChanged 事件添加一个动作:

    1. [mySegmentedControl addTarget:self action:@selector(selected:) forControlEvents:UIControlEventValueChanged];  

    只要选中了一个片段,你的动作方法就会被调用:

    1. -(void)selected:(id)sender{  
    2.     UISegmentedControl* control = (UISegmentedControl*)sender;  
    3.     switch (control.selectedSegmentIndex) {  
    4.         case 0:  
    5.             //   
    6.             break;  
    7.         case 1:  
    8.             //   
    9.             break;  
    10.         case 2:  
    11.             //   
    12.             break;  
    13.               
    14.         default:  
    15.             break;  
    16.     }  
    17. }  

    十、Demo

    最后附上我边写文章,边测试用的Demo:UISementedControlDemo

    免费下载地址在 http://linux.linuxidc.com/

    具体下载目录在 /2012年资料/3月/1日/UISegmentedControl 分段控件-iOS开发/

    用户名与密码都是www.linuxidc.com

  • 相关阅读:
    Nilearn教程系列(2)-3D和4D niimgs:处理和可视化
    Python-EEG工具库MNE中文教程(9)-参考电极应用
    EEMD算法原理与python实现
    Python-EEG工具库MNE中文教程(8)-参考电极简介
    联想笔记本 thinkpad BIOS 超级密码 Supervisor Password 清除 破解 亲测有效 转载地址https://blog.csdn.net/ot512csdn/article/details/72571674
    C Primer Plus 学习 第四章
    C Primer Plus 学习 第三章
    六 BASH 高级变量
    五 shell 变量与字符串操作
    四 shell基本命令
  • 原文地址:https://www.cnblogs.com/hvaven/p/3305361.html
Copyright © 2011-2022 走看看