Swift -- UIControl

  • 概述

UIControl 是控件的基类,通常指一些视觉元素(UIButtonUITextFieldUISliderUISwitch...),UIControl 通过传递特定的操作和意图(Target-Action Mechanism)来响应用户交互

您不能直接创建该类的实例,但您可以扩展它来实现自定义控件。您还可以子类化现有的控件类,以扩展或修改它们的行为。例如,您可以重写这个类的方法来自己跟踪触摸事件,或者确定控件的状态何时改变。

控件通常有几种状态(UIControl.State),不同的状态决定了控件不同的外观和能力
状态可以通过编程来改变,例如将控件的disabled设置为true可以禁止用户与控件进行交互。用户交互也可以改变控件的状态,例如点击一个 UIButton , 可以使 button 的状态由normal变为highlighted

  • Target-Action Mechanism

控件使用 Target-Action Mechanism 来报告特定的事件的发生,该机制简化了使用控件的流程,将对触摸事件的跟踪交给控件来完成,您只需要编写 Action 即可,而控件决定何时调用该 Action

通过addTarget(_:action:for:)声明控件使用的 Action 和定义该 ActionTarget,也可以通过 Interface Builder 来完成该配置。Target 通常是控件所在的 Root View 对应的 UIViewController,如果没有声明 Target,那么控件将会遍历 Responder Chain,直到找到实现了该控件对应的 ActionResponder

对触摸事件的跟踪处理请看:Swift -- Responder Chain

根据所需获取的信息,Action 可以有以下三种定义形式

@IBAction func doSomething()
@IBAction func doSomething(sender: Any)
@IBAction func doSomething(sender: Any, forEvent event: UIEvent)

sender 指的是与 Action 相关联的控件,event 指的是触发控件的事件 UIControl.Event
当特定类型的事件被控件监测到时,控件就会调用相关联的 Action(通过当前的 Application 对象动态分派),所以配置控件的时候还要指定事件的类型,例如对于 UIButton,可以指定 touchDowntouchUpInside 作为相关联的事件;而对于 UISlider,一般只关心该控件中值的变化,所以一般指定 valueChanged 作为相关联的事件

  • UIControl的相关属性

  • Alignment -- 这里指的是控件中内容的对齐,例如文本、图片,使用该属性来确定控件内容的位置
  • State -- 控件的初始状态,可以在 Interface Builder 的相关选项中进行配置
  • Accessibility

控件默认是 accessible 的,对于 accessible 的控件,必须提供准确的信息,例如控件在屏幕中的位置,名称,行为,值和类型等,这些信息会在 VoiceOver 中使用,以帮助有视力障碍的用户使用设备。

必要时候配置以下控件属性来为 Accessibility 提供支持

  • label : 一个简短的本地化单词或短语,简洁地描述控件或视图,但不标识元素的类型。例如“添加”或“播放”。
  • Traits : 一个或多个单独特征的组合,每个特征描述元素的状态、行为或使用情况。例如,一个键盘的元素且处于被选中的状态,可以通过该元素的值和所选特征的组合来对该元素进行描述。
  • Hint : 一个简短的、局部化的短语,描述对元素的操作的结果。例如“添加一个标题”或“打开购物清单”。
  • Frame : 元素在屏幕坐标系中的 frame,描述了元素在屏幕中的位置和大小
  • Value :元素的当前值,当该值不能由标签表示时使用。例如,滑块的标签可能是“Speed”,但是它的当前值可能是“50%”。

控件会默认提供 ValueFrame 的内容,很多控件也会自动配置 Traits 的内容

  • 子类化信息

通过子类化 UIControl 可以自定义控件的某些行为,例如

  1. 重写子类的sendAction(_:to:for:)方法以观察或修改将 Action 分派给特定 Target 的操作,可以使用此方法根据指定的对象、选择器或事件修改分派行为。
  2. 重写子类的beginTracking(_:with:),continueTracking(_:with:), endTracking(_:with:), cancelTracking(_:with:)方法以跟踪在当前控件中发生的触摸事件,可以利用以上方法定义在跟踪触摸事件时的额外操作。记得总是优先使用这些方法来跟踪触摸事件而不是 UIResponder 类定义的方法。
  • 参考文献

UIControl

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,546评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,224评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,911评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,737评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,753评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,598评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,338评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,249评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,696评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,888评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,013评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,731评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,348评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,929评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,048评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,203评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,960评论 2 355

推荐阅读更多精彩内容