首先不得不說 UIButton的父類就是UIControl
今天主要介紹UIControl的四種控件 UISwitch, UISlider, UISegmentedControl, UIPageControl
-
UISwitch
// UISwitch 的初始化
UISwitch *switch1 = [[UISwitch alloc] initWithFrame:CGRectMake(20, 50, 80, 30)];
// 設(shè)置開關(guān)開啟時的顏色
switch1.onTintColor = [UIColor greenColor];
// 設(shè)置開關(guān)移動點(diǎn)的顏色
switch1.thumbTintColor = [UIColor grayColor];
// 設(shè)置開關(guān)邊框的顏色
switch1.tintColor = [UIColor grayColor];
// 通過setter方法給開關(guān)的初始狀態(tài)賦值
switch1.on = NO;
[switch1 setOn:NO animated:NO];
// 給開關(guān)添加點(diǎn)擊事件
[switch1 addTarget:self action:@selector(switchAction:) forControlEvents:UIControlEventValueChanged];// switch點(diǎn)擊事件的實(shí)現(xiàn) - (void)switchAction:(UISwitch *)switch1 { // 根據(jù)switch狀態(tài)來決定他觸發(fā)的事件 if (switch1.on == YES) { NSLog(@"開"); } else if (switch1.on == NO) NSLog(@"關(guān)"); }
-
UISlider
// UISlider 初始化 (其中高度是系統(tǒng)設(shè)置好的)
UISlider *slider = [[UISlider alloc] initWithFrame:CGRectMake(20, 150, 300, 30)];
[self.view addSubview:slider];
// 設(shè)置slider的值(也就是滑動范圍)
slider.value = 50;
// 當(dāng)為"YES"時, 在觸發(fā)方法中 會連續(xù)的表現(xiàn)slider的變化 當(dāng)為"NO"時 知道鼠標(biāo)松開時 只顯示slider的一個最終值 沒有實(shí)時性
slider.continuous = YES;
// 設(shè)置slider圓點(diǎn)的顏色
slider.thumbTintColor = [UIColor grayColor];
// 設(shè)置slider滑過區(qū)域的顏色
slider.minimumTrackTintColor = [UIColor greenColor];
// 設(shè)置slider沒滑過區(qū)域的顏色
slider.maximumTrackTintColor = [UIColor blackColor];
// 也可以將slider各個部分設(shè)置為圖片
// 設(shè)置滑塊右邊的圖片
[slider setMaximumTrackImage: [UIImage imageNamed:@"player_slider_playback_right"] forState:UIControlStateNormal];
// 設(shè)置滑塊左邊的圖片
[slider setMinimumTrackImage:[UIImage imageNamed:@"player_slider_playback_left"] forState:UIControlStateNormal];
// 設(shè)置滑塊的圖片
[slider setThumbImage:[UIImage imageNamed:@"player_slider_playback_thumb"] f orState:UIControlStateNormal];
// 給slider加觸發(fā)方法
[slider addTarget:self action:@selector(sliderClick:) forControlEvents:UIControlEventValueChanged];// 觸發(fā)方法 - (void)sliderClick:(UISlider *)slider { NSLog(@"slider: %f", slider.value); }
UISegmentedControl (是一個包含很多button的控件)
// UISegmentedControl初始化
UISegmentedControl *segment = [[UISegmentedControl alloc] initWithItems:@[@"first", @"sec", @"thired"]];
// 如果不自己設(shè)置frame系統(tǒng)就會根據(jù)里面的內(nèi)容自動設(shè)置
segment.frame = CGRectMake(50, 100, 300, 30);
[self.view addSubview:segment];
// 設(shè)置顯示狀態(tài) 默認(rèn)為NO
segment.momentary = NO;
// 表示一個segment有多少item 注意 該屬性只有g(shù)etter方法 沒有setter方法
NSLog(@"%ld", segment.numberOfSegments);
// 向UISegmentedControl添加item(也就是button)
[segment insertSegmentWithTitle:@"確認(rèn)" atIndex:1 animated:YES];
// 修改 對應(yīng)下標(biāo)button的標(biāo)題
[segment setTitle:@"退出" forSegmentAtIndex:1];
// 設(shè)置對應(yīng)下標(biāo)button的寬度 默認(rèn)是系統(tǒng)給設(shè)置寬度 系統(tǒng)給平均分配
[segment setWidth:90 forSegmentAtIndex:0];
// 設(shè)置對應(yīng)下標(biāo)item中標(biāo)題的位置 (20, 0)表示向右偏移20 上下不偏移
[segment setContentOffset:CGSizeMake(0, 0) forSegmentAtIndex:0];
// 設(shè)置對應(yīng)下標(biāo)的button不能被選中
[segment setEnabled:NO forSegmentAtIndex:0];-
UIPageControl
UIPageControl *page = [[UIPageControl alloc] initWithFrame:CGRectMake(20, 100, 150, 30)];
page.backgroundColor = [UIColor blackColor];
[self.view addSubview:page];
page.numberOfPages = 7; // 分頁控制器頁數(shù)
page.currentPage = 2; // 顯示當(dāng)前頁
page.hidesForSinglePage = YES; // 當(dāng)page至有一頁 page會隱藏
// CGSize size = [page sizeForNumberOfPages:0]; // 獲取點(diǎn)的大小
// NSLog(@"%@", NSStringFromCGSize(size));
page.pageIndicatorTintColor = [UIColor redColor]; // 設(shè)置點(diǎn)點(diǎn)的顏色
page.currentPageIndicatorTintColor = [UIColor greenColor]; // 設(shè)置可移動點(diǎn)的顏色
page.defersCurrentPageDisplay = YES; // 默認(rèn)為NO 當(dāng)為YES 點(diǎn)點(diǎn) 不能移動 當(dāng)為NO時系統(tǒng)會配合點(diǎn)擊方法讓小點(diǎn)移動 當(dāng)為YES 必須調(diào)用 [page updateCurrentPageDisplay] 方法 小點(diǎn)才會移動// 給page綁定事件 [page addTarget:self action:@selector(pageClick:) forControlEvents:UIControlEventValueChanged];