IBInspectable创建下拉列表和更好的组织

时间:2014-11-04 21:37:59

标签: swift xcode6 ibdesignable

简而言之,我想创建一个@IBInspectable属性,当您在Storyboard中时,可以从下拉菜单中选择一系列内容。此外,如果有办法创建分隔线并更好地组织IBInspectables我想知道这是否也可行。在我的示例中,我想为电话号码创建正则表达式字符串,以便当我转到故事板时,我可以选择" 电话号码"下拉菜单中的项目,而不是输入正则表达式字符串。

目前我已经为TextField创建了子类,因此我可以为正则表达式添加更多IBInspectables(您可以在图片中看到)。因此,这就是我对我的子类UITextField所拥有的:

@IBDesignable public class FRM_TextField: UITextField {


@IBInspectable public var regex : String?

public var isValid : Bool{
    if let unwrappedRegex = regex{
        let applied_regex_expression = NSRegularExpression.regularExpressionWithPattern(unwrappedRegex, options: nil, error: nil)

        let numberOfMatches = applied_regex_expression?.numberOfMatchesInString(text, options: nil, range: NSMakeRange(0, countElements(text)))


        if(numberOfMatches > 0 ){
                return true
        }else{
                return false
        }
    }
    return false
}

  public required init(coder aDecoder: NSCoder) {
     super.init(coder: aDecoder)
}

  public override init(){
     super.init();
}

  public override init(frame: CGRect) {
     super.init(frame: frame)
  }   
}

Regex Toolbar

3 个答案:

答案 0 :(得分:12)

就组织而言,您可以通过命名属性来组织分隔符,以便它们具有相同的前缀。

@IBInspectable var ValText : Bool! = false
@IBInspectable var ValEmail : Bool! = false
@IBInspectable var ValCreditCard : Bool! = false
@IBInspectable var Positives : Bool! = false
@IBInspectable var Money : Bool! = false
@IBInspectable var Phone : Bool! = false
@IBInspectable var ZipCode : Bool! = false
@IBInspectable var Street : Bool! = false
@IBInspectable var IPAddress : Bool! = false
@IBInspectable var MAC : Bool! = false
@IBInspectable var AlphaNum : Bool! = false
@IBInspectable var AlphaNumSpaces : Bool! = false
@IBInspectable var AlphaNumNoSpaces : Bool! = false
@IBInspectable var URL : Bool! = false
@IBInspectable var ValidationType : String! = ""

呈现为

IB

答案 1 :(得分:11)

目前还不支持任何列表或数组。

目前,以下类型支持@IBInspectable

  • 内部
  • CGFloat的
  • 字符串
  • 布尔
  • CGPoint
  • CGSize
  • 的CGRect
  • 的UIColor
  • 的UIImage

这是一个包含所有可用IBInspectable的代码:

    @IBInspectable var integer: NSInteger = 10
    @IBInspectable var float: CGFloat = 10
    @IBInspectable var double: Double = 10
    @IBInspectable var string: String = "string"
    @IBInspectable var bool: Bool = true
    @IBInspectable var point: CGPoint = CGPointMake(1, 0)
    @IBInspectable var rect: CGRect = CGRectMake(0, 0, 100, 100)
    @IBInspectable var color: UIColor = UIColor.redColor()
    @IBInspectable var size: CGSize = CGSizeMake(100, 100)
    @IBInspectable var image: UIImage = UIImage(named: "Logo")!

它在IB看起来像这样:

enter image description here

答案 2 :(得分:7)

  

我想创建一个@IBInspectable属性,当您在Storyboard中时,可以从下拉菜单中选择一系列内容。

据我所知,还不支持列表(数组)。 到目前为止,受支持的类型是:

  • Int
  • CGFloat
  • Double
  • String
  • Bool
  • CGPoint
  • CGSize
  • CGRect
  • UIColor
  • UIImage
  

此外,如果有办法创建分隔线并更好地组织IBInspectables。

我不认为这样的事情是可能的。但也许有人有解决方法。

我建议您观看WWDC Session 411 - What's New in Interface Builder