zoukankan      html  css  js  c++  java
  • 自定义带DropDownTable的TextField(UI部分)

    这个自定义控件完全抄袭于GitHub.com上的一个项目,当做新手打字学习篇。

    思路

    (1),在TextField的下面创建一个UITableView,当在TextField输入文字的时候弹出这个table。

        为了让table浮在所有view的上面,需要调用superview.bringSubviewToFront();

      

    var dropTable:UITableView!

    dropTable = UITableView()


    superview!.addSubview(dropTable) superview!.bringSubviewToFront(dropTable)

    由于需要用到superview,不能允许在viewDidLoad中直接使用到superview.

    在初始化的时候给TextFiled增加一个编辑事件,侦听用户输入情况,当用户输入文字的时候弹出来

    func setupTextField(){
             addTarget(self, action: "editingChanged:",       forControlEvents:.EditingChanged)
        }
    
     func editingChanged(textField: UITextField) {
            if textField.text!.characters.count > 0 {
                setupTableView()
               // self.tableViewAppearanceChange(true)
            } else {
                if let dropDownTableView = dropTable {
                  //  self.tableViewAppearanceChange(false)
                }
            }
        }
    

    (2)设置约束使tableview的宽度正好跟TextFiled的宽度一致

     dropTable.translatesAutoresizingMaskIntoConstraints = false
                
                let leftConstraint = NSLayoutConstraint(item: dropTable, attribute: .Left, relatedBy: .Equal, toItem: self, attribute: .Left, multiplier: 1, constant: 0)
                let rightConstraint =  NSLayoutConstraint(item: dropTable, attribute: .Right, relatedBy: .Equal, toItem: self, attribute: .Right, multiplier: 1, constant: 0)
                heightConstraint = NSLayoutConstraint(item: dropTable, attribute: .Height, relatedBy: .Equal, toItem: nil, attribute: .NotAnAttribute, multiplier: 1, constant: dropDownTableViewHeight)
                let topConstraint = NSLayoutConstraint(item: dropTable, attribute: .Top, relatedBy: .Equal, toItem: self, attribute: .Bottom, multiplier: 1, constant: 1)
                
                NSLayoutConstraint.activateConstraints([leftConstraint, rightConstraint, heightConstraint, topConstraint])
    

     当用户点击除了tableview以外的地方,需要把tableview收起来。方法是给superview注册一个点击事件,判断点击区域

      let tapGesture = UITapGestureRecognizer(target: self, action: "tapped:")
     tapGesture.numberOfTapsRequired = 1
     tapGesture.cancelsTouchesInView = false
     superview!.addGestureRecognizer(tapGesture)
    
    
    func tapped(gesture: UIGestureRecognizer) {
            let location = gesture.locationInView(superview)
            if !CGRectContainsPoint(dropTable.frame, location) {
                if let dropTable = dropTable {
                    
                    dropTable.hidden = true
                    //self.tableViewAppearanceChange(false)
                }
    } }

    I am not doing shit today !
  • 相关阅读:
    HDU 1348 Wall
    HDU 2202 最大三角形
    HDU 2215 Maple trees
    HDU 1147 Pick-up sticks
    HDU 1392 Surround the Trees
    风语时光
    HDU 1115 Lifting the Stone
    HDU 1086 You can Solve a Geometry Problem too
    HDU 2108 Shape of HDU
    HDU 3360 National Treasures
  • 原文地址:https://www.cnblogs.com/mogul/p/5157617.html
Copyright © 2011-2022 走看看