• ios学习笔记之UIControl解读


    UIControl,相信大家对其并不陌生吧,比如平常最常用的UIButton就是继承自UIControl的。按照惯例,还是先来看看为什么有UIControl这个类?什么时候用到它?

    查下文档就可以看到其是继承自UIView的,而对于其用途,官方对其有这么一段描述:

    简要点说,就是当你需要自定义一个类似于button的控件,也可自定义响应事件。而要这些,你必须实现相应的方法。详情可看下官方文档。

    简要挑几个比较常用有代表性的属性和方法:

    contentHorizontalAlignment:

    这个属性主要是用于设置你自定义的这个空间里面的text or image在水平方向上的位置,而同样的另一个对应属性contentVerticalAlignment则用于设置垂直方向上的位置属性,取值可如下:

    typedef enum {
       UIControlContentHorizontalAlignmentCenter = 0,
       UIControlContentHorizontalAlignmentLeft    = 1,
       UIControlContentHorizontalAlignmentRight = 2,
       UIControlContentHorizontalAlignmentFill   = 3,
    } UIControlContentHorizontalAlignment;
    typedef enum {
       UIControlContentVerticalAlignmentCenter  = 0,
       UIControlContentVerticalAlignmentTop     = 1,
       UIControlContentVerticalAlignmentBottom  = 2,
       UIControlContentVerticalAlignmentFill    = 3,
    } UIControlContentVerticalAlignment;
    • state selected highlighted

    • 这几个从字面上就能看出其作用,而对于其相应的state,ios对其有以下定义:
    enum {
       UIControlStateNormal               = 0,
       UIControlStateHighlighted          = 1 << 0,
       UIControlStateDisabled             = 1 << 1,
       UIControlStateSelected             = 1 << 2,
       UIControlStateApplication          = 0x00FF0000,
       UIControlStateReserved             = 0xFF000000
    };

    看完了上面几个属性,再来看下一个最常用的方法:
    - (void)addTarget:(id)target action:(SEL)action forControlEvents:(UIControlEvents)controlEvents

      target:目标,通常取值self
      action:一个sel值,用于定义一个方法,然后当你点击后面的controlEvents相应事件时开始执行。eg.@selector(myMethod:)
      controlEvents:事件,详情看上面的state定义。


    不宜太长,就写这么多先,主要用到的就这么几个,但就是很常用,最近项目经常会写这类的自定义控件。


  • 相关阅读:
    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) D
    HDU 2036 求任意多边形面积板子题
    HDU 6703 array(主席树)
    2019牛客暑期多校训练营(第九场)H Cutting BamboosO(二分、主席树)
    lintcode-425-电话号码的字母组合
    lintcode-81-数据流中位数
    lintcode-424-逆波兰表达式求值
    lintcode-423-有效的括号序列
    lintcode-422-最后一个单词的长度
    lintcode-421-简化路径
  • 原文地址:https://www.cnblogs.com/mapleyuan/p/3276527.html
Copyright © 2020-2023  润新知