- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
UISwitch *swit = [[UISwitch alloc] initWithFrame:CGRectMake(, , , )];
[self.view addSubview:swit];
// 3. (开关按钮)圆圈的颜色
swit.thumbTintColor = [UIColor yellowColor];
// switch 宽和高不影响控件, 只有x和y
// 1. 开启时的控件内部颜色
swit.onTintColor = [UIColor blueColor];
// 2. 边框及切换到关闭的时的颜色(non_resettable)
swit.tintColor = nil;
// 4. 打开时的图片, ios7后失效
swit.onImage = [UIImage imageNamed:@""];
// 5. 关闭时的图片, 也失效
swit.offImage = [UIImage imageNamed:@""];
// 6. 判断switchControl的开闭状态
// 通过setter方法, 给变switchControl的初始状态
swit.on = YES;
NSLog(@"%@", swit.isOn ? @"yes" : @"no");
[swit setOn:YES animated:NO];
// 添加绑定事件(与button相同)
[swit addTarget:self action:@selector(switchAction:) forControlEvents:UIControlEventValueChanged]; // slider
// 高度不影响控件的高度, 这个控件永远居中与视图中间
UISlider *slider = [[UISlider alloc]initWithFrame:CGRectMake(, , , )];
[self.view addSubview:slider];
// slider.minimumValueImage = [UIImage imageNamed:@"456"];
// 1. 滑块最大值和最小值, 最大和最小可以根据需求去改变
slider.maximumValue = 200.0f;
// 2. 当前滑块的值
slider.value = 50.0f;
[slider setValue: animated:YES];
// 3. 最小值和最大值显示的图片
// maximumValueImage minimumValueImage
// 4. containous 为no时, 只在按下和松手是触发方法
slider.continuous = NO;
NSLog(@"%@", slider.isContinuous ? @"yes" : @"no");
// 5. 绑定事件
[slider addTarget:self action:@selector(sliderAction:) forControlEvents:UIControlEventValueChanged]; CGRect rect = [slider maximumValueImageRectForBounds:slider.bounds];
NSLog(@"%f, %f", rect.size.width, rect.size.height);
// 8. maximumTrackTintColor 未移动到的区域的颜色
slider.maximumTrackTintColor = [UIColor blueColor];
// 9. minimumTrackTintColor 已移动的区域的颜色
slider.minimumTrackTintColor = [UIColor whiteColor];
// 10. 滑块的颜色
// slider.thumbTintColor = [UIColor blueColor];
// 11. 设置进度条滑块左边的图片
[slider setMinimumTrackImage:[UIImage imageNamed:@"player_slider_playback_right"] forState:UIControlStateNormal];
// 12. 设置进度条滑块右边的图片
[slider setMaximumTrackImage:[UIImage imageNamed:@"player_slider_playback_left"] forState:UIControlStateNormal];
// 13. 设置圆圈的图片
[slider setThumbImage:[UIImage imageNamed:@"player_slider_playback_thumb"] forState:UIControlStateNormal]; self.seg = [[UISegmentedControl alloc] initWithItems:@[@"first", @"second", @"last", @"one", @"two"]];
// segment不给frame, 系统会自动计算大小, 推荐, 自己加上frame
self.seg.frame = CGRectMake(, , , );
[self.view addSubview:self.seg];
// 1. momentary 设置为yes 如果点击选中没有选中的效果,
// 默认为NO
self.seg.momentary = YES;
// 2. seg的控制段的数量
NSInteger number = self.seg.numberOfSegments;
NSLog(@"分段控制器的段数:(items的个数) %ld", number);
// 3. remove 移除
// 4. insertSegmentWithTitle:@"name" atIndex:2 animated:YES 插入
// 5. setTitle:forSegmentAtIndex: 用来修改对应下标的标题
// 6. setWidth:0 forSegmentAtIndex: 默认是0
[self.seg setWidth: forSegmentAtIndex:];
// 7. setContentOffset:<#(CGSize)#> forSegmentAtIndex:<#(NSUInteger)#> 设置对应下标内容的偏移
[self.seg setContentOffset:CGSizeMake(, ) forSegmentAtIndex:];
// 8. 能否被选中
[self.seg setEnabled:NO forSegmentAtIndex:];
// 9. selectedSegmentIndex 开始选中的下标
self.seg.selectedSegmentIndex = ;
// 10. tintColor文字及边框颜色
self.seg.tintColor = [UIColor greenColor];
// 11. apportionsSegmentWidthsByContent 默认为no
// 如果分段控制器的段宽为0时, 并且该属性为YES, 系统会自动计算
self.seg.apportionsSegmentWidthsByContent = YES;
// 12. 绑定事件
[self.seg addTarget:self action:@selector(segAction:) forControlEvents:UIControlEventValueChanged]; UIPageControl *page = [[UIPageControl alloc] initWithFrame:CGRectMake(, , , )];
page.backgroundColor = [UIColor blackColor];
// 1. 分页控制器的页数 默认为 0
page.numberOfPages = ;
// 2. 当前页
page.currentPage = ;
// 3. 当只有一页的时候pageControl隐藏
page.hidesForSinglePage = YES;
// 4.
CGSize size = [page sizeForNumberOfPages:];
NSLog(@"size++%@", NSStringFromCGSize(size));
// 其他页的颜色
page.pageIndicatorTintColor = [UIColor redColor];
// 当前页的颜色
page.currentPageIndicatorTintColor = [UIColor whiteColor];
[self.view addSubview:page];
// 绑定事件
[page addTarget:self action:@selector(pageControllChange:) forControlEvents:UIControlEventValueChanged];
// 设置为yes, 关闭系统事件page的切换, 直到调用updateCurrentPageDisplay的方法, 才会显示
page.defersCurrentPageDisplay = YES;
}
- (void)pageControllChange:(UIPageControl *)page {
NSLog(@"Change");
[page updateCurrentPageDisplay];
}
- (void)segAction:(UISegmentedControl *)seg {
NSLog(@"%ld", seg.selectedSegmentIndex);
switch (seg.selectedSegmentIndex) {
case : break;
case : break;
// ....
default:
break;
}
}
//
- (void)sliderAction:(UISlider *)slider {
NSLog(@"%f", slider.value); }
- (void)switchAction:(UISwitch *)swit {
NSLog(@"开关事件");
[self.seg insertSegmentWithTitle:@"name" atIndex: animated:YES];
[self.seg insertSegmentWithImage:[UIImage imageNamed:@"player_slider_playback_thumb"] atIndex: animated:YES];
}
- (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning];
// Dispose of any resources that can be recreated.
}

UIControl的子类UISwitch, UISegmentedCntrol, UIPageControl详解的更多相关文章

  1. 【iOS 开发】基本 UI 控件详解 (UIButton | UITextField | UITextView | UISwitch)

    博客地址 : http://blog.csdn.net/shulianghan/article/details/50051499 ; 一. UI 控件简介 1. UI 控件分类 UI 控件分类 : 活 ...

  2. iOS:核心动画的详解介绍:CAAnimation(抽象类)及其子类

    核心动画的详解介绍:CAAnimation(抽象类)   1.核心动画基本概念 Core Animation是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍! 使用它 ...

  3. Python 在子类中调用父类方法详解(单继承、多层继承、多重继承)

    Python 在子类中调用父类方法详解(单继承.多层继承.多重继承)   by:授客 QQ:1033553122   测试环境: win7 64位 Python版本:Python 3.3.5 代码实践 ...

  4. Java多态性详解——父类引用子类对象

    来源:http://blog.csdn.net/hikvision_java_gyh/article/details/8957456 面向对象编程有三个特征,即封装.继承和多态. 封装隐藏了类的内部实 ...

  5. 第7.20节 案例详解:Python抽象类之真实子类

    第7.20节 案例详解:Python抽象类之真实子类 上节介绍了Python抽象基类相关概念,并介绍了抽象基类实现真实子类的步骤和语法,本节结合一个案例进一步详细介绍. 一.    案例说明 本节定义 ...

  6. 第7.19节 Python中的抽象类详解:abstractmethod、abc与真实子类

    第7.19节 Python中的抽象类详解:abstractmethod.abc与真实子类 一.    引言 前面相关的章节已经介绍过,Python中定义某种类型是以实现了该类型对应的协议为标准的,而不 ...

  7. iOS开发——UI篇&ScrollView详解

    创建方式 1:StoryBoard/Xib 这里StoarBoard就不多说,直接拖就可以,说太多没意思,如果连这个都不会我只能先给你跪了! 2:代码: CGRect bounds = [ [ UIS ...

  8. ScrollView详解

    创建方式 1:StoryBoard/Xib 这里StoarBoard就不多说,直接拖就可以,说太多没意思,如果连这个都不会我只能先给你跪了! 2:代码: 1 2 3 CGRect bounds = [ ...

  9. 《招一个靠谱的移动开发》iOS面试题及详解(上篇)

    以下问题主要用于技术的总结与回顾 主要问题总结 单例的写法.在单利中创建数组应该注意些什么. NSString 的时候用copy和strong的区别. 多线程.特别是NSOperation 和 GCD ...

随机推荐

  1. [Linux][Ubuntu18.04.1] nginx+php+MySQL环境搭建

    说在前面 今天在腾讯云的CVM服务器搭建了一下环境[主机:标准型S2,Unbuntu18.04的LST版本] 采用了nginx服务器(Nginx 静态处理性能比 Apache高3倍以上,不过apach ...

  2. 使用php扩展mcrypt实现AES加密

    AES(Advanced Encryption Standard,高级加密标准)是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用.Rijndael是 ...

  3. 生成元(UVa1583)

    题目具体描述见:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_prob ...

  4. 语言模型srilm基本用法

    目录: 一基本训练 二语言模型打分 三语言模型剪枝 四语言模型合并 五语言模型使用词典限制 一.基本训练 #功能 读取分词后的text文件或者count文件,然后用来输出最后汇总的count文件或者语 ...

  5. js求连个数之间的数字

    整理出自项目中一个需求,求两个数之间的数字. const week = function(arr,arr2){ let a=parseInt(arr); let b=parseInt(arr2); l ...

  6. Redis实战(五)

    删除Redis中数据 using (var redisClient = RedisManager.GetClient()) { var user = redisClient.GetTypedClien ...

  7. MVC Partial页面的使用

    先建立Action: public PartialViewResult CurrentCount() { ViewBag.Count = CurrentUserCount; return Partia ...

  8. /.nav-tabs :是普通标签页 .nav-pills:胶囊式标签页 action ;默认的激活项,给<li>加默认显示的是哪个标签页内容 .nav是标签页的一个基类,给ul加 .nav-stacked: 垂直排列BootStrap

    <meta name="viewport" content="with=device-width, initial-scale=1, user-scalabe=no ...

  9. Xml配置文件属性的说明

    Xml配置文件属性的说明: <bean id="TheAction" ⑴ class="net.xiaxin.spring.qs.UpperAction" ...

  10. BZOJ2754 [SCOI2012]喵星球上的点名 SA+莫队+树状数组

    题面 戳这里 题解 首先先把所有给出的姓名和询问全部接在一起,建出\(height\)数组. 某个串要包含整个询问串,其实就相当于某个串与询问串的\(lcp\)为询问串的长度. 而两个后缀\(Suff ...