UIControl-IOS开发

UIControl-IOS开发

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

UIKit提供了一组控件:UISwitch开关、UIButtonbutton、UISegmentedControl分段控件、UISlider滑块、UITextField文本字段控件、

UIPageControl分页控件。

控件是对UIView派生类的有用增强及补充,并能够直接附着于导航栏、表格单元,甚至更大的对象。

这些控件的基类均是UIControl,而UIControl派生自UIView类,所以每一个控件都有非常多视图的特性,包含附着于其它视图的能力。全部

控件都拥有一套共同的属性和方法。

所以学习控件,我们先学习UIControl

属性


enabled


控件默认是启用的。要禁用控件,能够将enabled属性设置为NO,这将导致控件忽略不论什么触摸事件。被禁用后,控件还能够用不同的方式显示自己,比方变成灰色不可用。尽管是由控件的子类完毕的,这个属性却存在于UIControl中。

selected

当用户选中控件时,UIControl类会将其selected属性设置为YES。子类有时使用这个属性来让控件选择自身,或者来表现不同的行为方式。

contentVerticalAlignment

控件怎样在垂直方向上布置自身的内容。默认是将内容顶端对其,对于文本字段,可能会改成UIControlContentVerticalAlignmentCenter。对于这个字段,能够使用下列诸值:

1. UIControlContentVerticalAlignmentCenter  

2. UIControlContentVerticalAlignmentTop  

3. UIControlContentVerticalAlignmentBottom  

4. UIControlContentVerticalAlignmentFill

 


contentHorizontalAlignment


水平方向

1. UIControlContentHorizontalAlignmentCenter  

2. UIControlContentHorizontalAlignmentTop  

3. UIControlContentHorizontalAlignmentBottom  

4. UIControlContentHorizontalAlignmentFill  

事件通知


UIControl类提供了一个标准机制,来进行事件登记和接收。这令你能够指定你的控件在发生特定事件时,通知代理类的一个方法。假设要注冊一个事件,能够使用addTarget方

法:

[ myControl addTarget: myDelegate   action:@selector(myActionmethod:)  forControlEvents:UIControlEventValueChanged ];

事件能够用逻辑OR合并在一起,因此能够再一次单独的addTarget调用中指定多个事件。下列事件为基类UIControl所支持,除非另有说明,也适用于全部控件


UIControlEventTouchDown

单点触摸按下事件:用户点触屏幕,或者又有新手指落下的时候。


UIControlEventTouchDownRepeat

多点触摸按下事件,点触计数大于1:用户按下第二、三、或第四根手指的时候。


UIControlEventTouchDragInside

当一次触摸在控件窗体内拖动时。


UIControlEventTouchDragOutside

当一次触摸在控件窗体之外拖动时。


UIControlEventTouchDragEnter

当一次触摸从控件窗体之外拖动到内部时。


UIControlEventTouchDragExit

当一次触摸从控件窗体内部拖动到外部时。


UIControlEventTouchUpInside

全部在控件之内触摸抬起事件。


UIControlEventTouchUpOutside

全部在控件之外触摸抬起事件(点触必须開始与控件内部才会发送通知)。


UIControlEventTouchCancel

全部触摸取消事件,即一次触摸由于放上了太多手指而被取消,或者被上锁或者电话呼叫打断。


UIControlEventTouchChanged

当控件的值发生改变时,发送通知。用于滑块、分段控件、以及其它取值的控件。你能够配置滑块控件何时发送通知,在滑块被放下时发送,或者在被拖动时发送。


UIControlEventEditingDidBegin

当文本控件中開始编辑时发送通知。


UIControlEventEditingChanged

当文本控件中的文本被改变时发送通知。


UIControlEventEditingDidEnd

当文本控件中编辑结束时发送通知。


UIControlEventEditingDidOnExit

当文本控件内通过按下回车键(或等价行为)结束编辑时,发送通知。


UIControlEventAllEditingEvents

通知全部关于文本编辑的事件。


UIControlEventAllEvents

通知全部事件。


要删除一个或多个事件的对应动作,能够使用UIControl类的removeTarget方法。使用nil值就能够将给定事件目标的全部动作删除:

[ myControl removeTarget:myDelegate   action:nil  forControlEvents:UIControlEventAllEvents];

  

要取得关于一个控件全部指定动作的列表,能够使用allTargets方法。这种方法返回一个NSSet,当中包括事件的完整列表:

NSSet* myActions = [myConreol allTargets ];  


另外,你还能够用actionsForTarget方法,来获取针对某一特定事件目标的所有动作列表:

NSArray* myActions = [ myControl actionForTarget:UIControlEventValueChanged ];  


假设设计了一个自己定义控件类,能够使用sendActionsForControlEvent方法,为主要的UIControl事件或自己的自己定义事件发送通知。比如,假设你的控件值正在发生变化,就能够

发送对应通知,通过控件的代码能够指定时间目标,这个通知将被传播到这些指定的目标。例:

[ self sendActionsForControlEvents:UIControlEventValueChanged ]; 


当托付类得到事件通知时,他将收到一个指向事件发送者的指针。以下的样例用于处理分段控件的事件,你的动作方法(action method)应遵循类似的处理方式:

-(void) myAction:(id)sender{  

       UISegmentedControl* control = (UISegmentedControl*)sender;  

       if(control == myControl1){  

       /*查询控件得值*/  

      /*响应myControl1的动作*/  

       }  
}  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118324.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Angular面试题_vue框架面试题

    Angular面试题_vue框架面试题一、ng-show/ng-hide与ng-if的区别?第一点区别是,ng-if在后面表达式为true的时候才创建这个dom节点,ng-show是初始时就创建了,用display:block和display:none来控制显示和不显示。第二点区别是,ng-if会(隐式地)产生新作用域,ng-switch、ng-include等会…

    2025年11月18日
    6
  • python模拟键盘输入_python控制鼠标键盘

    python模拟键盘输入_python控制鼠标键盘win32api.keybd_event该函数原型:keybd_event(bVk,bScan,dwFlags,dwExtraInfo)第一个参数:虚拟键码(键盘键码对照表见附录);第二个参数:硬件扫描码,一般设置为0即可;第三个参数:函数操作的一个标志位,如果值为KEYEVENTF_EXTENDEDKEY则该键被按下,也可设置为0即可,如果值为KEYEVENTF_KEYUP则该按键被释放;…

    2022年10月11日
    2
  • hbuilder安装使用教程_ghost使用教程图解

    hbuilder安装使用教程_ghost使用教程图解前段时间朋友让我帮忙打包一个IPA文件(使用HTML5开发的Web应用),了解到HBuilder这款H5开发神器。之前一直使用WebStorm开发H5,闲来无事也学习下HB

    2022年8月5日
    4
  • vagrant系列三:vagrant搭建的php7环境

    vagrant系列三:vagrant搭建的php7环境

    2022年2月8日
    74
  • 【032】JavaScript 计算笛卡尔积[通俗易懂]

    【032】JavaScript 计算笛卡尔积[通俗易懂]这是一个用JavaScript实现笛卡尔积的例子。注意:本文中所说的集合是指数学上的集合,不是es6里的Set。整体思路如下:用户传入一个二维的数组,每个子数组都是一个要进行笛卡尔积计算的集合。返回一个二维数组,每个子数组都是一个有序对或者n元有序组。当用户传入一个集合的时候,为了兼容业务,返回形如:[[a],[b]…]的二维数组。当用户只传入两个集合计算的时候,普通的嵌套计算即可。当用

    2022年7月11日
    14
  • p6使用说明_人员配置情况说明

    p6使用说明_人员配置情况说明P6SPY 是一个监控JDBC执行语句的开源产品,利用P6SPY很容易的就能监控到JDBC中执行的SQL语句,便于系统调试和性能调优。P6SPY 实现原理是对JDBC的关键类进行了一次包装,让应用系统调用自己的类;自己的类截获到SQL语句后再调用真实的JDBC驱动进行执行SQL,这样,在自己的类里面就可以监控到所有的SQL语句。    P6SPY 使用非常简单,只需要简单的几步即完成配置:

    2022年10月5日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号