Swift(十五)控件(UIControl)

更新:2018.05.24

整理了一下demo:SwiftDemo


在iOS系统中,控件是专门为与用户交互设置及的UIControl类及其子类,子类包括UIButton、UITextField、UISwitch、UIPageControl、UISegmentedControl、UIDataPicker、UISlider等。
UIControl继承自UIView,所以UIControl具备UIView的可视化功能。
UIControl专门为与用户交互而设计的主要体现在UIControl类中增加了Target-Action机制,利用这种机制,用户就可以在iOS的世界自由翱翔了。

一、Target-Action机制

  • UIControl类引入了Target-Action(目标行为模式)机制,那么它所有的子类也就自然拥有了这种机制,通过Target-Action机制,实现与用户交互。
  • 不仅仅是Target-Action机制能实现用户交互,还有delegate设计模式、手势等都能实现用户交互。
  • Target-Action能够识别来自用户的操作行为,这些用户操作行为被ios系统定义在UIControlEvents结构体中,UIControlEvents主要包括3种:
    • 基于触摸的控件事件。
    • 基于值的控件事件。
    • 基于编辑的控件事件。
属性 描述
触摸事件 -
TouchDown 表示控件边界内任何地方发生的按下(手指触到屏幕)事件。
TouchUpInside 表示控件便捷内任何地方发生抬起来(手指离开屏幕)事件
TouchUpOutside 表示手指完全落在控件的边界外的事件
TouchDragEnter 表示拖拽进入控件边界内的事件
TouchDragExit 表示拖拽移出控件边界内的事件
TouchCancel 表示取消当前的一个触摸的系统事件
AllTouchEvents 表示用于捕捉一切触摸事件
值事件 -
ValueChanged 表示控件的值发生变化后出发的事件,如UITextField的text发生变化。
编辑事件 -
EditingDidBegin 表示TextField控件内部的触摸开始事件,表示TextField开始编辑状态(获得焦点)
EditingDidEnd 表示TextField控件外部的触摸结束事件,表示TextField结束编辑状态(失去焦点)
EditingChanged 表示TextField的内容编辑修改时触发的事件
EditingDidEndOnExit 表示结束编辑会话事件,但不一定是控件的外边界触摸事件
AllEditingEvents 表示用于捕捉任意编辑事件
ApplicationReserved 表示应用程序的特定事件
SystemReserved 表示系统(内部的框架)特定事件
PrimaryActionTriggered 表示semantic action
AllEnvnts 表示用于捕捉任何触摸、值、编辑、应用程序、系统事件

二、UIControl类的方法和属性

因为UIControl是所有控件的父类,所以它的方法和属性子类都会继承,我们了解了UIControl类的方法和属性,会更好的理解其子类。

属性名称 方法说明
alignment alignmentInterface Builder属性,控件的content的水平和垂直对齐方式所说的content就是文本或内容,例如:UIbutton、UITextField。可以使用alignment去配置content在控件bounds的对其方式,需要注意的是,这里的对齐方式不是指控件在其父视图中的对齐方式。
content 首先要说明这是Interface Builder属性,控件的初始化状态。使用这个checkbox可以选择Selected、Enabled、Hightlighted
state 控件的状态,state是一个只读属性,它返回值都是UIControlType,但是要特别说明的是,当我们调用state属性时,得到的可能不仅仅是UIContralType中的一个值,而是多个值,比如focusedhightlighted
enabled 是否开启,仅在控件的该属性处于开启的情况下,用户的触摸事件才是有效的。
selected 是否选中,一般的控件不会用到它的选中状态,但有一些是会的,例如UISegmentedControl会实现它的选中状态
hightlighted 是否高亮,控件的hightlighted状态是指手指点击到控件且没有松手的时候,在APP中,一般会针对hightlighted做特别的设置。
contentVerticalAlignment 内容的垂直对齐方式,对于那些可以配置文本或图片的控件来说,文本或图片就是控件的内容,那么这个属性就是可以配置文本或图片的垂直对齐方式。
contentHorizontalAlignment 内容水平对齐方式,同contentVerticalAlignment

在代码中,contentHorizontalAlignmentcontentVerticalAlignment归属于Alignment属性;
enabledhightlightedselected归属于Content属性。

方法名 方法说明
sendAction(_ action: Selector, to target: Any?, for event: UIEvent?) 通过此方法调用指定的方法,就是把当前控件、方法、方法所属的对象、事件等关联起来,进行手动调用,这个方法不常用,主要被其他系统方法调用
sendActions(for controlEvents: UIControlEvents) 调用与指定事件关联的方法。
addTarget(_ target: Any?, action: Selector, for controlEvents: UIControlEvents) 关联指定对象、指定方法和指定的事件。这样可以让指定的对象的方法在用户有指定的行为时被调用。比较常用
removeTarget(_ target: Any?, action: Selector?, for controlEvents: UIControlEvents) 移除当前控件上指定对象的关联方法
actions(forTarget target: Any?, forControlEvent controlEvent: UIControlEvents) 获取绑定在指定对象和指定事件发生时候的方法数组
allTargets: Set<AnyHashable> { get } 获取与当前控件关联的所有对象。
allControlEvents: UIControlEvents { get } 获取与当前控件本身关联的所有事件
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,419评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,016评论 4 62
  • Swift版本点击这里欢迎加入QQ群交流: 594119878最新更新日期:18-09-17 About A cu...
    ylgwhyh阅读 25,278评论 7 249
  • *面试心声:其实这些题本人都没怎么背,但是在上海 两周半 面了大约10家 收到差不多3个offer,总结起来就是把...
    Dove_iOS阅读 27,121评论 29 470
  • 从前有个国王带着大臣一起去打猎,在打猎的过程中,国王的小拇指被野兽咬掉了,回到皇宫以后,有个大臣说这也未尝不是一件...
    枫叶凡阅读 1,073评论 0 1