亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

iOS App開發(fā)中的UISegmentedControl分段組件用法總結(jié)

 更新時間:2016年06月08日 09:39:12   作者:劉偉  
UISegmentedControl主要被用來制作分頁按鈕或添加跳轉(zhuǎn)到不同位置的標簽,這里我們就來看一下iOS App開發(fā)中的UISegmentedControl分段組件用法總結(jié),需要的朋友可以參考下

UISegmentedControl分段控件代替了桌面OS上的單選按鈕。不過它的選項個數(shù)非常有限,因為你的IOS設(shè)備屏幕有限。當我們需要使用選項非常少的單選按鈕時它很合適。
一、創(chuàng)建

復(fù)制代碼 代碼如下:

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


是不是很奇怪沒有指定位置和大小呢?沒錯,我確實在他的類聲明里只找到 initWithItems 而未找到 initWithFrame ,所以他不需要指定,不過我看到了另一個方法,這個方法可以設(shè)置Item的寬度:
復(fù)制代碼 代碼如下:

mySegmentedControl setWidth:100 forSegmentAtIndex:0];//設(shè)置Item的寬度 

二、屬性
復(fù)制代碼 代碼如下:

mySegmentedControl.segmentedControlStyle = UISegmentedControlStyleBar;//風(fēng)格 

可以視使用的場合,有三種風(fēng)格選擇,如下:
復(fù)制代碼 代碼如下:

typedef enum { 
    UISegmentedControlStylePlain,     // large plain 有灰邊的大白按鈕,適合偏好設(shè)置單元 
    UISegmentedControlStyleBordered,  // large bordered 黑邊的大白按鈕,適用于表格單元 
    UISegmentedControlStyleBar,       // small button/nav bar style. tintable 小按鈕,適合導(dǎo)航欄 
    UISegmentedControlStyleBezeled,   // large bezeled style. tintable 
} UISegmentedControlStyle; 

如果你使用的是 UISegmentedControlStyleBar 風(fēng)格,還可以用空間的 tintColor 屬性為整個控件設(shè)置渲染色彩:
復(fù)制代碼 代碼如下:

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

三、添加、刪除片段
每個分段控件的片段都是一個按鈕,其中包含一個標簽或圖片。你需要在你的控件中為每個控件創(chuàng)建一個片段。只要屏幕放得下,就可以有許多片段,但用戶同一時刻只能選擇一個片段。
復(fù)制代碼 代碼如下:

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

每個
按鈕都被賦予一個索引,用這個索排序以及標識。
你也可以添加一個含有圖像的片段,用inserSegmentWithImage
復(fù)制代碼 代碼如下:

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

刪除片段
復(fù)制代碼 代碼如下:

[mySegmentedControl removeSegmentAtIndex:0 animated:YES];//刪除一個片段 
[mySegmentedControl removeAllSegments];//刪除所有片段

四、片段標題
復(fù)制代碼 代碼如下:

[mySegmentedControl setTitle:@"ZERO" forSegmentAtIndex:0];//設(shè)置標題 
NSString* myTitle = [mySegmentedControl titleForSegmentAtIndex:1];//讀取標題 

五、圖像
每個分段也可以設(shè)置圖像:
復(fù)制代碼 代碼如下:

[mySegmentedControl setImage:[UIImage imageNamed:@"pic"] forSegmentAtIndex:1];//設(shè)置 
UIImage* myImage = [mySegmentedControl imageForSegmentAtIndex:2];//讀取 

注意:圖像不會自動調(diào)整大小,圖片多大就會原生地顯示多大,所以你要通知做圖的美工大小要精確。

六、選中分段
分段控件的默認行為是,一旦按鈕被選中就一直保持,直到另外一個按鈕被選中為止。你可以改變這種默認的行為,變成按鈕按下后很快就自動釋放。將控件的momentary屬性設(shè)為YES:

復(fù)制代碼 代碼如下:

mySegmentedControl.momentary = YES; 

注意:開啟這個功能后點觸片段不會更新 selectedSegmentedIndex,因此也就無法通過這個屬性得到當前選取的片段。
初始化默認片段
默認情況下,除非你指定,否則不會有任何片段被選中。要設(shè)置 selectedSegmentedIndex 屬性:
復(fù)制代碼 代碼如下:

mySegmentedControl.selectedSegmentedIndex = 0; 

七、顯示控件
復(fù)制代碼 代碼如下:

[parentView addSubview:mySegmentedControl];//添加到父視圖 

或 
復(fù)制代碼 代碼如下:

self.navigationItem.titleView = mySegmentedControl;//添加到導(dǎo)航欄 

八、讀取控件
通過 selectedSegmentedIndex 屬性,可以讀取當前選中分段的值,這個值就是選中片段的索引號。
復(fù)制代碼 代碼如下:

int x = mySegmentedControl. selectedSegmentedIndex; 

九、通知
要接收片段選取的通知,可以用UIControl類的 addTarget 方法,為 UIControlEventValueChanged 事件添加一個動作:
復(fù)制代碼 代碼如下:

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

只要選中了一個片段,你的動作方法就會被調(diào)用:
復(fù)制代碼 代碼如下:

-(void)selected:(id)sender{ 
    UISegmentedControl* control = (UISegmentedControl*)sender; 
    switch (control.selectedSegmentIndex) { 
        case 0: 
            // 
            break; 
        case 1: 
            // 
            break; 
        case 2: 
            // 
            break; 
             
        default: 
            break; 
    } 


十、設(shè)置圓角以及設(shè)置選中顏色為空
復(fù)制代碼 代碼如下:

UISegmentedControl *seg = [[UISegmentedControl alloc]initWithItems:[NSArray arrayWithObjects:@"設(shè)置",@"知道了", nil]];

seg.frame = CGRectMake(10,0, CGRectGetWidth(self.view.frame) - 20, 35);

seg.center = isbluetoothOffAlerView.center;

seg.layer.borderColor = [UIColor whiteColor].CGColor;

seg.layer.borderWidth = 2;

seg.tintColor = [UIColor whiteColor];

seg.backgroundColor = [UIColor clearColor];

NSDictionary *dic = [NSDictionary dictionaryWithObjectsAndKeys:[UIColor whiteColor], NSForegroundColorAttributeName,[UIFont systemFontOfSize:24],NSFontAttributeName,nil];

[seg setTitleTextAttributes:dic forState:UIControlStateNormal];

seg.layer.cornerRadius = 15;

seg.layer.masksToBounds = YES;

相關(guān)文章

  • iOS Swift創(chuàng)建代理協(xié)議的多種方式示例

    iOS Swift創(chuàng)建代理協(xié)議的多種方式示例

    這篇文章主要給大家介紹了關(guān)于iOS Swift創(chuàng)建代理協(xié)議的多種方式,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-12-12
  • 最新評論